# HDL Compiler<sup>™</sup> (Presto VHDL) Reference Manual

Version C-2009.06, June 2009

SYNOPSYS®

## **Copyright Notice and Proprietary Information**

Copyright © 2009 Synopsys, Inc. All rights reserved. This software and documentation contain confidential and proprietary information that is the property of Synopsys, Inc. The software and documentation are furnished under a license agreement and may be used or copied only in accordance with the terms of the license agreement. No part of the software and documentation may be reproduced, transmitted, or translated, in any form or by any means, electronic, mechanical, manual, optical, or otherwise, without prior written permission of Synopsys, Inc., or as expressly provided by the license agreement.

## **Right to Copy Documentation**

The license agreement with Synopsys permits licensee to make copies of the documentation for its internal use only. Each copy shall include all copyrights, trademarks, service marks, and proprietary rights notices, if any. Licensee must assign sequential numbers to all copies. These copies shall contain the following legend on the cover page:

| "This document is duplicated with the permission of Sy | ynopsys, Inc., for the exclusive use of |
|--------------------------------------------------------|-----------------------------------------|
|                                                        | and its employees. This is copy number  |

#### **Destination Control Statement**

All technical data contained in this publication is subject to the export control laws of the United States of America. Disclosure to nationals of other countries contrary to United States law is prohibited. It is the reader's responsibility to determine the applicable regulations and to comply with them.

#### Disclaimer

SYNOPSYS, INC., AND ITS LICENSORS MAKE NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.

### Registered Trademarks (®)

Synopsys, AMPS, Astro, Behavior Extracting Synthesis Technology, Cadabra, CATS, Certify, CHIPit, Design Compiler, DesignWare, Formality, HDL Analyst, HSIM, HSPICE, Identify, iN-Phase, Leda, MAST, ModelTools, NanoSim, OpenVera, PathMill, Physical Compiler, PrimeTime, SCOPE, Simply Better Results, SiVL, SNUG, SolvNet, Syndicated, Synplicity, Synplify Pro, Synthesis Constraints Optimization Environment, TetraMAX, the Synplicity logo, UMRBus, VCS, Vera, and YIELDirector are registered trademarks of Synopsys, Inc.

#### Trademarks (™)

AFGen, Apollo, Astro-Rail, Astro-Xtalk, Aurora, AvanWaves, BEST, Columbia, Columbia-CE, Confirma, Cosmos, CosmosLE, CosmosScope, CRITIC, CustomSim, DC Expert, DC Professional, DC Ultra, Design Analyzer, Design Vision, DesignerHDL, DesignPower, DFTMAX, Direct Silicon Access, Discovery, Eclypse, Encore, EPIC, Galaxy, Galaxy Custom Designer, HANEX, HAPS, HapsTrak, HDL Compiler, Hercules, Hierarchical Optimization Technology, High-performance

ASIC Prototyping System, HSIM plus in invitable some plus in invitable some plus plus in invitable some plus plus in invitable some plus invitable some plus in invitable some plus in invitable some plus in invitable some plus invit

## Service Marks (<sup>SM</sup>)

MAP-in, SVP Café, and TAP-in are service marks of Synopsys, Inc.

SystemC is a trademark of the Open SystemC Initiative and is used under license. ARM and AMBA are registered trademarks of ARM Limited. Saber is a registered trademark of SabreMark Limited Partnership and is used under license. All other product or company names may be trademarks of their respective owners.

|    | What's New in This Release                                                                                                                                              | xiv                                  |
|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|
|    | About This Reference Manual                                                                                                                                             | xiv                                  |
|    | Customer Support                                                                                                                                                        | xvii                                 |
| 1. | Introduction to HDL Compiler (Presto VHDL)                                                                                                                              |                                      |
|    | Reading Designs  Summary of Reading Methods  Using the analyze and elaborate Commands  Using the read Command  Automatic Detection of RTL Language From File Extensions | 1-3<br>1-4<br>1-4<br>1-5<br>1-6      |
|    | Elaboration Reports                                                                                                                                                     | 1-7                                  |
|    | Reporting Elaboration Errors  Methodology  Example  hdlin_elab_errors_deep FAQs                                                                                         | 1-8<br>1-9<br>1-10<br>1-15           |
|    | Parameterized Models (Generics)                                                                                                                                         | 1-17                                 |
|    | Configuration Support                                                                                                                                                   | 1-20<br>1-21<br>1-23<br>1-24<br>1-27 |
|    | Example 6: Port Map in a Configuration                                                                                                                                  | 1-30                                 |

|    | Example 7: Nested Configurations                                                                                               |
|----|--------------------------------------------------------------------------------------------------------------------------------|
|    | Example 8: Indirectly Nested Configurations                                                                                    |
|    | Example 9: Embedded Configurations                                                                                             |
|    | Example 10: Multiple Architectures in Embedded Configurations - Last Chosen as Default                                         |
|    | Example 11: Combinations of Embedded, Nested, and Stand-Alone Configurations Require Elaborate with a Configuration Identifier |
|    | Design Libraries                                                                                                               |
|    | Predefined Design Libraries                                                                                                    |
|    | Creating User-Defined Design Libraries                                                                                         |
|    | User-Defined Design Library Example                                                                                            |
|    | Using Design Units From Design Libraries                                                                                       |
|    | Design Library Reports                                                                                                         |
|    | Package Support                                                                                                                |
|    | Array Naming Variables                                                                                                         |
|    | Licenses                                                                                                                       |
| 2. | General Coding Considerations                                                                                                  |
|    | Declarative Region in generate Statements                                                                                      |
|    |                                                                                                                                |
|    | Design Units                                                                                                                   |
|    | Default Component Port Assignments                                                                                             |
|    | Component Name Restrictions                                                                                                    |
|    | Component Sources                                                                                                              |
|    | Component Port Consistency                                                                                                     |
|    | Instantiating Technology-Independent Components                                                                                |
|    | Component Architecture                                                                                                         |
|    | Package Names                                                                                                                  |
|    | Procedures and Functions as Design Components                                                                                  |
|    | Data Types and Data Objects                                                                                                    |
|    | Globally Static Expressions in Port Maps                                                                                       |
|    | Aliases                                                                                                                        |
|    | Deferred Constants                                                                                                             |

| Aggregates in Constant Record Declarations              | 2-15         |
|---------------------------------------------------------|--------------|
| Enumerated Types in the for and for-generate Constructs | 2-16         |
| Groups                                                  | 2-17         |
| Integer Data Types                                      | 2-17         |
| Overloading an Enumeration Literal                      | 2-18         |
| Enumeration Encoding                                    | 2-18         |
| Constant Floating-Point Support                         | 2-19         |
| Syntax and Declarations                                 | 2-19         |
| Operators and Expressions                               | 2-20         |
| Guidelines                                              | 2-21         |
| math_real Package Support                               | 2-22         |
| Unsupported Constructs and Operators                    | 2-22         |
| Using the math_real Package                             | 2-22<br>2-22 |
| Arithmetic Functions                                    | 2-22<br>2-23 |
|                                                         |              |
| Operands                                                | 2-24         |
| Operand Bit-Width                                       | 2-24         |
| Array Slice Names                                       | 2-25         |
| Computable and Noncomputable Operands                   | 2-25         |
| Indexed Name Targets                                    | 2-28         |
| Modeling Considerations                                 | 2-28         |
| Concatenation                                           | 2-28         |
| Unconstrained Type Ports                                | 2-30         |
| Input Ports Associated With the Keyword open            | 2-30         |
| Multiple Events in a Single Process                     | 2-30         |
| Keeping Signal Names                                    | 2-31         |
| Controlling Structure                                   | 2-32         |
| Resolution Functions                                    | 2-33         |
| Asynchronous Designs                                    | 2-34         |
| Using Don't Care Values                                 | 2-34         |
| Finite State Machines                                   | 2-35         |
| Variables and Commands Specific to FSM Inference        | 2-35         |
| FSM Coding Requirements                                 | 2-36         |
| FSM Example and Inference Report                        | 2-37         |
| State Vector Attribute                                  | 2-39         |
| Multibit Inference                                      | 2-40         |
| Multibit Inference Overview                             | 2-40         |

|    | Controlling Multibit Inference                                                                                                                                                                                                                 | 2-40<br>2-4                                  |
|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|
|    | Simulation/Synthesis Mismatch Issues.  Type Mismatches. Set and Reset Signals. Z Values in Expressions Don't Care Values in Comparisons Ordering of Enumerated Types Using the ENUM_ENCODING attribute Sensitivity Lists Delay Specifications. | 2-44<br>2-44<br>2-44<br>2-44<br>2-45<br>2-46 |
| 3. | Modeling Combinational Logic                                                                                                                                                                                                                   |                                              |
|    | Synthetic Operators                                                                                                                                                                                                                            | 3-2                                          |
|    | Logic and Arithmetic Operator Implementation                                                                                                                                                                                                   | 3-4                                          |
|    | Propagating Constants                                                                                                                                                                                                                          | 3-5                                          |
|    | Bit-Truncation Coding for DC Ultra Datapath Extraction                                                                                                                                                                                         | 3-5                                          |
|    | Multiplexing Logic  SELECT_OP Inference  MUX_OP Inference  Variables That Control MUX_OP Inference  MUX_OP Inference Examples  MUX_OP Inference Limitations                                                                                    | 3-8<br>3-8<br>3-10<br>3-12<br>3-14<br>3-16   |
|    | Unintended Latches and Feedback Paths in Combinational Logic                                                                                                                                                                                   | 3-17                                         |
| 4. | Modeling Sequential Logic                                                                                                                                                                                                                      |                                              |
|    | Generic Sequential Cells (SEQGENs)                                                                                                                                                                                                             | 4-2                                          |
|    | Inference Reports for Flip-Flops and Latches                                                                                                                                                                                                   | 4-4                                          |
|    | Register Inference Variables                                                                                                                                                                                                                   | 4-5                                          |
|    | Register Inference Attributes                                                                                                                                                                                                                  | 4-6                                          |
|    | Inferring D and Set/Reset (SR) Latches                                                                                                                                                                                                         | 4-7<br>4-7                                   |

5.

| Inferring D Latches Overview—Latch Inference Basic D Latch D Latch With Asynchronous Set D Latch With Asynchronous Reset D Latch With Asynchronous Set and Reset Limitations of D Latch Inference | 4-9<br>4-10<br>4-11<br>4-12<br>4-13<br>4-14 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|
| Inferring D Flip-Flops                                                                                                                                                                            | 4-14                                        |
| Overview—Inferring D Flip-Flops                                                                                                                                                                   | 4-15                                        |
| Enabling Conditions in if Statements                                                                                                                                                              | 4-16                                        |
| Positive-Edge-Triggered D Flip-Flop                                                                                                                                                               | 4-16                                        |
| Negative-Edge-Triggered D Flip-Flop                                                                                                                                                               | 4-18                                        |
| D Flip-Flop With Asynchronous Set                                                                                                                                                                 | 4-19                                        |
| D Flip-Flop With Asynchronous Reset                                                                                                                                                               | 4-20                                        |
| D Flip-Flop With Asynchronous Set and Reset                                                                                                                                                       | 4-21                                        |
| D Flip-Flop With Synchronous Set                                                                                                                                                                  | 4-22                                        |
| D Flip-Flop With Synchronous Reset                                                                                                                                                                | 4-23                                        |
| D Flip-Flop With Complex Set/Reset Signals                                                                                                                                                        | 4-25<br>4-26                                |
| D Flip-Flop With Synchronous and Asynchronous Load                                                                                                                                                | 4-20<br>4-27                                |
| Inferring JK Flip-Flops                                                                                                                                                                           | 4-29                                        |
| Basic JK Flip-Flop                                                                                                                                                                                | 4-29                                        |
| JK Flip-Flop With Asynchronous Set and Reset                                                                                                                                                      | 4-31                                        |
| Inferring Master-Slave Latches                                                                                                                                                                    | 4-32                                        |
| Master-Slave Latch Overview                                                                                                                                                                       | 4-32                                        |
| Master-Slave Latch: Single Master-Slave Clock Pair                                                                                                                                                | 4-33                                        |
| Master-Slave Latch: Multiple Master-Slave Clock Pairs                                                                                                                                             | 4-33                                        |
| Master-Slave Latch: Discrete Components                                                                                                                                                           | 4-35                                        |
| Limitations of Register Inference                                                                                                                                                                 | 4-36                                        |
| Unloaded Sequential Cell Preservation                                                                                                                                                             | 4-37                                        |
| Inferring Three-State Logic                                                                                                                                                                       |                                             |
| Inference Report for Three-State Devices                                                                                                                                                          | 5-2                                         |
| Inferring a Basic Three-State Driver                                                                                                                                                              | 5-2                                         |
| Inferring One Three-State Buffer From a Single Process                                                                                                                                            | 5-3                                         |

|    | Inferring Two Three-State Buffers                                                                                                                                                                           | 5-4                                           |
|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
|    | Three-State Buffer With Registered Enable                                                                                                                                                                   | 5-6                                           |
|    | Three-State Buffer With Registered Data                                                                                                                                                                     | 5-7                                           |
|    | Understanding the Limitations of Three-State Inference                                                                                                                                                      | 5-9                                           |
| 6. | Directives, Attributes, and Variables                                                                                                                                                                       |                                               |
|    | Directives  keep_signal_name.  template.  translate_off and translate_on  synthesis_off and synthesis_on  resolution_method.  map_to_entity and return_port_name  dc_tcl_script_begin and dc_tcl_script_end | 6-2<br>6-2<br>6-2<br>6-2<br>6-3<br>6-3<br>6-3 |
|    | Attributes                                                                                                                                                                                                  | 6-5<br>6-5<br>6-11<br>6-11                    |
| 7. | Write Out Designs in VHDL Format                                                                                                                                                                            |                                               |
|    | Netlist Writer Variables                                                                                                                                                                                    | 7-2<br>7-2                                    |
|    | VHDL Write Variables                                                                                                                                                                                        | 7-3                                           |
|    | Bit and Bit-Vector Variables                                                                                                                                                                                | 7-5                                           |
|    | Resolution Function Variables                                                                                                                                                                               | 7-6                                           |
|    | Types and Type Conversion Variables                                                                                                                                                                         | 7-7                                           |
|    | Architecture and Configuration Variables                                                                                                                                                                    | 7-8                                           |
|    | Preserving Port Types                                                                                                                                                                                       | 7-9                                           |
|    | VHDL Netlister Coding Considerations.  Built-In Type Conversion Function.  How the Netlister Handles Custom Types.  Case Sensitivity.                                                                       | 7-11<br>7-11<br>7-12<br>7-13                  |
|    |                                                                                                                                                                                                             |                                               |

| Appendix A. | Examples |
|-------------|----------|
|-------------|----------|

| Read-Only Memory                                                | A-2                      |
|-----------------------------------------------------------------|--------------------------|
| Waveform Generator                                              | A-4                      |
| Definable-Width Adder-Subtracter                                | A-6                      |
| Count Zeros—Combinational Version                               | A-7                      |
| Count Zeros—Sequential Version                                  | A-9                      |
| Soft Drink Machine—State Machine Version                        | A-11                     |
| Soft Drink Machine—Count Nickels Version                        | A-14                     |
| FSM Example: Moore Machine                                      | A-16                     |
| FSM Example: Mealy Machine                                      | A-18                     |
| Carry-Lookahead Adder                                           | A-20<br>A-20<br>A-25     |
| Serial-to-Parallel Converter—Counting Bits                      | A-26<br>A-26<br>A-27     |
| Serial-to-Parallel Converter—Shifting Bits                      | A-31                     |
| Programmable Logic Arrays                                       | A-33                     |
| Appendix B. Predefined Libraries                                |                          |
| std_logic_1164                                                  | B-2<br>B-2               |
| std_logic_arith                                                 | B-4<br>B-4               |
| Modifying the std_logic_arith Packagestd_logic_arith Data Types | B-6<br>B-7<br>B-7<br>B-7 |
| Conversion Functions                                            | B-8<br>B-9               |
| Comparison FunctionsShift Functions                             | B-12<br>B-14             |

Contents ix

|       | Multiplication Using Shifts          | B-15       |
|-------|--------------------------------------|------------|
| nu    | umeric_std                           | B-15       |
|       | Unsupported Constructs and Operators | B-16       |
|       | Using the numeric_std Package        | B-16       |
|       | numeric_std Data Types               | B-16       |
|       | Conversion Functions                 | B-17       |
|       | Resize Functions                     | B-17       |
|       | Arithmetic Functions                 | B-17       |
|       | Comparison Functions                 | B-19       |
|       | Defining Logical Operators Functions | B-22       |
|       | Shift and Rotate Functions           | B-23       |
|       | Shift and Rotate Operators           | B-24       |
| sto   | d_logic_misc                         | B-26       |
| St    | tandard Package                      | B-27       |
|       | Data Type BOOLEAN                    | B-28       |
|       | Data Type BIT                        | B-28       |
|       | Data Type CHARACTER                  | B-28       |
|       | Data Type INTEGER                    | B-29       |
|       | Data Type NATURAL                    | B-29       |
|       | Data Type POSITIVE                   | B-29       |
|       | Data Type STRING                     | B-29       |
|       | Data Type BIT_VECTOR                 | B-29       |
| Sy    | ynopsys Package—ATTRIBUTES           | B-29       |
| Annen | ndix C. VHDL Constructs              |            |
|       |                                      | 0.0        |
| VH    | HDL Construct Support                | C-2        |
|       | Configurations                       | C-2        |
|       | Design Units                         | C-2        |
|       | Data Types                           | C-3        |
|       | Declarations                         | C-4        |
|       | Specifications                       | C-5        |
|       | Names                                | C-6<br>C-7 |
|       | Operands and Expressions             | C-7        |
|       | Operands and Expressions             | C-9        |
|       | Seudeniiai Sialemenis                | U-10       |

Contents x

| Concurrent Statements                                    | C-11 |
|----------------------------------------------------------|------|
| Lexical Elements                                         | C-12 |
| Specifics of Identifiers                                 | C-12 |
| Specifics of Extended Identifiers                        | C-12 |
| Predefined Language Environment                          | C-13 |
| VHDL Reserved Words                                      | C-13 |
| Appendix D. New Features and Enhancements in Presto VHDL |      |
| VHDL-93 Supported Features                               | D-2  |
| New Features and Enhancements History                    | D-7  |
| Glossary                                                 |      |
| Index                                                    |      |

Contents xi

Contents xii

## **Preface**

This preface includes the following sections:

- What's New in This Release
- About This Reference Manual
- Customer Support

### What's New in This Release

Information about new features, enhancements, and changes, along with known problems, limitations, and resolved Synopsys Technical Action Requests (STARs), is available in the *HDL Compiler (Synthesis) Release Notes* in SolvNet.

To see the HDL Compiler (Synthesis) Release Notes,

1. Go to

https://solvnet.synopsys.com/ReleaseNotes

If prompted, enter your user name and password. If you do not have a Synopsys user name and password, follow the instructions to register with SolvNet.

2. Click HDL Compiler (Synthesis), then select a release in the list that appears at the bottom.

### **About This Reference Manual**

Presto VHDL translates a VHDL hardware language description into a GTECH netlist that is used by the Design Compiler tool to create an optimized netlist. This manual describes the following:

- Modeling combinational logic, synchronous logic, three-state buffers, and multibit cells with Presto VHDL
- Using Presto VHDL directives, attributes, and variables

#### **Audience**

The HDL Compiler (Presto VHDL) Reference Manual is written for logic designers and electronic engineers who are familiar with Design Compiler. Knowledge of the VHDL language is required, and knowledge of a high-level programming language is helpful.

#### **Related Publications**

For additional information about Presto VHDL, see Documentation on the Web, which is available through SolvNet at the following address:

https://solvnet.synopsys.com/DocsOnWeb

You might also want to refer to the documentation for the following related Synopsys products:

- Design Compiler
- DesignWare
- Library Compiler
- VHDL System Simulator

## **Conventions**

The following conventions are used in Synopsys documentation.

| Convention     | Description                                                                                                                                                                                                                                      |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Courier        | Indicates command syntax.                                                                                                                                                                                                                        |
| Courier italic | Indicates a user-defined value in Synopsys syntax, such as <code>object_name</code> . (A user-defined value that is not Synopsys syntax, such as a user-defined value in a Verilog or VHDL statement, is indicated by regular text font italic.) |
| Courier bold   | Indicates user input—text you type verbatim—in Synopsys syntax and examples. (User input that is not Synopsys syntax, such as a user name or password you enter in a GUI, is indicated by regular text font bold.)                               |
| []             | Denotes optional parameters, such as pin1 [pin2 pinN]                                                                                                                                                                                            |
| I              | Indicates a choice among alternatives, such as low   medium   high (This example indicates that you can enter one of three possible values for an option: low, medium, or high.)                                                                 |
| _              | Connects terms that are read as a single term by the system, such as set_annotated_delay                                                                                                                                                         |
| Control-c      | Indicates a keyboard combination, such as holding down the Control key and pressing c.                                                                                                                                                           |
| \              | Indicates a continuation of a command line.                                                                                                                                                                                                      |
| /              | Indicates levels of directory structure.                                                                                                                                                                                                         |
| Edit > Copy    | Indicates a path to a menu command, such as opening the Edit menu and choosing Copy.                                                                                                                                                             |

## **Customer Support**

Customer support is available through SolvNet online customer support and through contacting the Synopsys Technical Support Center.

## **Accessing SolvNet**

SolvNet includes an electronic knowledge base of technical articles and answers to frequently asked questions about Synopsys tools. SolvNet also gives you access to a wide range of Synopsys online services including software downloads, documentation on the Web, and "Enter a Call to the Support Center."

To access SolvNet, go to the SolvNet Web page at the following address:

#### https://solvnet.synopsys.com

If prompted, enter your user name and password. If you do not have a Synopsys user name and password, follow the instructions to register with SolvNet.

If you need help using SolvNet, click HELP in the top-right menu bar or in the footer.

## **Contacting the Synopsys Technical Support Center**

If you have problems, questions, or suggestions, you can contact the Synopsys Technical Support Center in the following ways:

- Open a call to your local support center from the Web by going to http://solvnet.synopsys.com (Synopsys user name and password required), and then clicking "Enter a Call to the Support Center."
- Send an e-mail message to your local support center.
  - E-mail support center@synopsys.com from within North America.
  - Find other local support center e-mail addresses at http://www.synopsys.com/Support/GlobalSupportCenters/Pages
- Telephone your local support center.
  - Call (800) 245-8005 from within the continental United States.
  - Call (650) 584-4200 from Canada.
  - Find other local support center telephone numbers at http://www.synopsys.com/Support/GlobalSupportCenters/Pages

# 1

## Introduction to HDL Compiler (Presto VHDL)

The Synopsys Design Compiler tool uses the HDL Compiler (Presto VHDL) tool to read designs written in the VHDL hardware description language.

#### Note:

This manual also refers to the HDL Compiler (Presto VHDL) as Presto VHDL.

For a list of supported VHDL-93 features, see "VHDL-93 Supported Features" on page D-2. For other new features, see "New Features and Enhancements History" on page D-7.

This chapter contains the following sections:

- Reading Designs
- Elaboration Reports
- Reporting Elaboration Errors
- Parameterized Models (Generics)
- Configuration Support
- Design Libraries
- Package Support
- Array Naming Variables
- Licenses

## **Reading Designs**

When Presto VHDL reads a VHDL design, it checks the code for correct VHDL syntax and builds the generic technology (GTECH) netlist that Design Compiler uses to optimize the design. You can use the read command to do both functions automatically, or you can use the analyze and elaborate commands to do each function separately. It is recommended that you use the analyze and elaborate commands instead of the read command, because

- The elaborate command includes the functionality of the link command, which resolves design references.
- For parameterized designs, the read command builds a design only with the default generic value; if you want to build a new design with a nondefault value, you must use analyze and elaborate. See "Parameterized Models (Generics)" on page 1-17.
- The read command ignores stand-alone configurations.

Beginning with the X-2006.06 release, Presto VHDL supports automatic linking of mixed language libraries. In Verilog, the default library is the work directory, and you cannot have multiple libraries. In VHDL, however, you can have multiple design libraries. In earlier versions, Presto VHDL could not link mixed libraries and returned LINK-5 warnings.

If you want to read a VHDL netlist, use the specialized VHDL netlist reader instead of Presto VHDL. The VHDL netlist reader reads netlists faster and uses less memory.

#### **Important:**

To enable the VHDL netlist reader, you must set <code>enable\_vhdl\_netlist\_reader</code> to true (the default is false) and use the netlist reading commands shown in Table 1-1 on page 1-4.

If the file is not a VHDL netlist or if <code>enable\_vhdl\_netlist\_reader</code> is set to false, Presto VHDL reads the design.

This section contains the following subsections:

- Summary of Reading Methods
- Using the analyze and elaborate Commands
- Using the read Command
- Automatic Detection of RTL Language From File Extensions

## **Summary of Reading Methods**

The recommended and alternative reading commands are shown in Table 1-1.

Table 1-1 Reading Commands

| Type of input       | Reading method                                                                                                                                                                              |  |  |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| RTL                 | Recommended reading method  analyze -format vhdl { files } elaborate <topdesign></topdesign>                                                                                                |  |  |
|                     | Alternative reading method read_vhdl { files } (tcl) read_file -format vhdl { files } (tcl)                                                                                                 |  |  |
| Gate-level netlists | Recommended reading method  set enable_vhdl_netlist_reader true read_vhdl -netlist { files } (tcl)  or  set enable_vhdl_netlist_reader true read_file -format vhdl -netlist { files } (tcl) |  |  |
|                     | Alternative reading method<br>Any RTL-reading command also works for reading netlists, but is slower and<br>uses more memory than the specialized gate-level netlist reader.                |  |  |

## Using the analyze and elaborate Commands

When you are elaborating a design, the last analyzed architecture is used if you do not specify an architecture.

To understand how to use the analyze and elaborate commands, consider Example 1-1, which represents a single design with no user-defined libraries.

#### Example 1-1 Design dff\_pos

```
library IEEE ;
use IEEE.std_logic_1164.all;
entity dff_pos is
  port (DATA, CLK : in std_logic;
       Q : out std_logic);
end dff_pos;

architecture rtl of dff_pos is
begin
process (CLK) begin
  if (rising_edge (CLK)) then
```

```
Q <= DATA;
end if;
end process;
end rtl;
```

Example 1-2 through Example 1-4 show various reading methods.

#### Example 1-2

```
--The analyze and elaborate commands read design dff_pos which is contained
--in a single file, dff_entity_arch.vhd.

dc_shell> analyze -format vhdl dff_entity_arch.vhd
dc shell> elaborate dff pos
```

#### Example 1-3

```
--Design dff_pos is contained in two files, dff_entity.vhd and dff_arch.vhd.
--Each file is analyzed by a separate analyze command and then the --dff_pos design is elaborated.

dc_shell> analyze -format vhdl dff_entity.vhd dc_shell> analyze -format vhdl dff_arch.vhd dc_shell> elaborate dff_pos
```

#### Example 1-4

```
--Design dff_pos is contained in two files, dff_entity.vhd and dff_arch.vhd.
--Both files are analyzed using a single analyze command, and then elaborated.

dc_shell> analyze -format vhdl {dff_entity.vhd dff_arch.vhd} dc_shell> elaborate dff_pos
```

## **Using the read Command**

For you to use any read command, all your entity/architecture definitions must be contained in a single read. The entity and architecture definitions may be contained in separate files. Table 1-2 on page 1-6 shows various reading examples.

When you use the read command, you must also use the current\_design command, to specify the working design, and the link command, to resolve design references, before optimizing the design. These operations are automatically done by the elaborate

command. If you have configurations, you must use analyze. The read command ignores configurations and has limited supported for generics. See "Configuration Support" on page 1-20 and "Parameterized Models (Generics)" on page 1-17.

Table 1-2 read Command Examples

| Example                                                                     | Description                                                                                     |  |  |
|-----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|--|--|
| dc_shell-t> read_file -format vhdl ALU.vhd                                  | The read_file command reads the single design in the ALU.vhd file.                              |  |  |
| dc_shell-t> read_vhdl ALU.vhd                                               | The read_vhdl command reads the single design in the ALU.vhd file.                              |  |  |
| <pre>dc_shell-t&gt; read_vhdl {ALU_subblock.vhd ALU_top.vhd}</pre>          | The read_vhdl command reads a design consisting of two files: ALU_subblock.vhd and ALU_top.vhd. |  |  |
| dc_shell-t> read_vhdl ALU_subblock.vhd<br>dc_shell-t> read_vhdl ALU_top.vhd | Two read_vhdl commands read a design consisting of two files: ALU_subblock.vhd and ALU_top.vhd. |  |  |

## **Automatic Detection of RTL Language From File Extensions**

You can specify a file format with the read\_file command by using the -format option. If you do not specify a format, read\_file infers the format based on the file extension. If the file extension in unknown, the format is assumed to be .ddc. The file extensions in Table 1-3 are supported for automatic inference:

Table 1-3 Supported File Extensions for Automatic Inference

| Format | File extensions                             |
|--------|---------------------------------------------|
| ddc    | .ddc                                        |
| db     | .db, .sldb, .sdb, .db.gz, .sldb.gz, .sdb.gz |
| VHDL   | .vhd, .vhdl, . vhd.gz, .vhdl.gz             |

The supported extensions are not case sensitive. All formats except .ddc can be compressed in gzip (.gz) format.

If you specify a file format that is not supported, Design Compiler generates an error message. For example, if you specify  $read\_file test.vlog$ , Design Compiler issues the following DDC-2 error message:

Error: Unable to open file 'test.vlog' for reading. (DDC-2)

## **Elaboration Reports**

You can control the type and the amount of information that is included in elaboration reports by setting the hdlin\_reporting\_level variable to basic, comprehensive, verbose, or none. Table 1-4 shows what is included in the report based on each setting. In the table, true indicates that the information will be included in the report, false indicates that it will not be included in the report, and verbose indicates that the report will include detailed information. If you do not specify a setting, hdlin\_reporting\_level is set to basic by default.

Table 1-4 Basic hdlin\_reporting\_level Variable Settings

| Information included in report                                         | none  | basic | comprehensive | verbose |
|------------------------------------------------------------------------|-------|-------|---------------|---------|
| floating_net_to_ground Reports the floating net to ground connections. | false | false | true          | true    |
| fsm Prints a report of inferred state variables.                       | false | false | true          | true    |
| inferred_modules Prints a report of inferred sequential elements.      | false | true  | true          | verbose |
| mux_op Prints a report of MUX_OPs.                                     | false | true  | true          | true    |
| syn_cell Prints a report of synthetic cells.                           | false | false | true          | true    |
| tri_state Prints a report of inferred three-state elements.            | false | true  | true          | true    |

In addition to the basic settings, you can also specify the add (+) or subtract (-) options to customize a report. For example, if you want a report to include floating net-to-ground connections, synthetic cells, inferred state variables, and verbose information for inferred sequential elements, but you do not want to include MUX\_OPs or inferred three-state elements, you can set the hdlin\_reporting\_level variable to the following setting:

set hdlin\_reporting\_level verbose-mux\_op-tri\_state

As another example, if you set the hdlin\_reporting\_level variable to the following setting,

set hdlin\_reporting\_level basic+floating\_net\_to\_ground+syn\_cell+fsm

HDL Compiler issues a report that is equivalent to set hdlin\_reporting\_level comprehensive, meaning that the elaboration report will include comprehensive information for all the information listed in the first column in Table 1-4.

## **Reporting Elaboration Errors**

HDL Compiler (Presto VHDL) elaborates designs in a top-down hierarchical order. The elaboration failure of a top-level module prohibits the elaboration of all associated submodules. The hdlin\_elab\_errors\_deep variable allows the elaboration of submodules even if the top-level module elaboration fails, enabling Presto VHDL to report more elaboration, link, and VER-37 errors and warnings in a hierarchical design during the first elaboration run.

To understand how this variable works, consider the four-level hierarchical design in Figure 1-1 on page 1-9. This design has elaboration (ELAB) errors as noted in the figure.

Figure 1-1 Hierarchical Design



Under default conditions, when you elaborate the design, Presto VHDL reports only the errors in the first level (ELAB-368 and ELAB-298 in module A). To find the second-level error (ELAB-298 in submodule D), you need to fix the first-level errors and elaborate again.

When you use the hdlin\_elab\_errors\_deep variable, you only need to elaborate once to find the errors in module A and submodule D.

The next section describes the hdlin\_elab\_errors\_deep variable and provides methodology, examples, and a list of frequently asked questions (FAQ).

## Methodology

Use the following methodology to enable Presto VHDL to report elaboration, link, and VER-37 errors across the hierarchy during a single elaboration run.

- 1. Identify and fix all syntax errors in the design.
- Set hdlin\_elab\_errors\_deep to true.When you set this variable to true, Presto VHDL reports

"Presto compilation run in rtl debug mode."

## Important:

Important: Presto VHDL does not create designs when you set hdlin\_elab\_errors\_deep to true. The tool reports warnings if you try to use commands that require a design. For example, if you run list\_design, the tool reports

"Warning: No designs to list. (UID-275)"

- 3. Elaborate your design using the elaborate command.
- 4. Fix any elaboration, link, and VER-37 errors. Review the warnings and fix errors as needed.
- 5. Set hdlin\_elab\_errors\_deep to false.
- 6. Elaborate your error-free design.
- 7. Proceed with your normal synthesis flow.

The next section provides examples showing Presto VHDL reporting all errors across the hierarchy, reducing the need for multiple elaboration runs.

## **Example**

This section uses a design to show Presto VHDL's hierarchical error reporting capability which is made available through the hdlin\_elab\_errors\_deep variable. Figure 1-2 on page 1-11 shows the block diagram for design Top; Example 1-5 on page 1-11 shows the RTL code. The design errors are noted in the figure.

Figure 1-2 Hierarchical Design



## Example 1-5 VHDL RTL for Design Top

```
-- entity top
entity top is
port (clk, a, b : in bit;
     c, o: out bit);
end entity top;
architecture A1 of top is
component sub1 is
port ( a, b : in bit;
               : out bit);
end component sub1;
component sub2 is
port (a, b : in bit;
               : out bit);
end component sub2;
begin
 sub1_inst: sub1 port map (a, b, c);
 sub2_inst: sub2 port map (a, b, o);
end A1;
-- entity sub1
library IEEE;
use IEEE.std_logic_1164.all;
entity sub1 is
port ( a, b : in bit;
```

```
o : out bit);
end entity sub1;
architecture A1 of sub1 is
component foo is
end component foo;
 signal r : bit_vector(1 downto 0);
 signal temp, sig, sig1 : std_logic;
 constant icon : integer := 5;
begin
 temp <= TO STDULOGIC(a or b);</pre>
 temp <= '1'; -- ELAB-368 error
 temp <= sig and 'Z'; -- ELAB-306 error
 foo_inst: foo port map (a, b, o);
end A1;
-- entity foo
library IEEE;
use IEEE.std_logic_1164.all;
entity foo is
end entity foo;
architecture Al of foo is
component bar is
end component bar;
signal temp : bit;
begin
   bar_inst: bar port map(a, b, o);
end A1;
-- entity bar
entity bar is
end entity bar;
architecture A1 of bar is
begin
  o <= not b;
end A1;
-- entity sub2
entity sub2 is
end entity sub2;
```

```
architecture A1 of sub2 is
begin
    o <= a or b;
end A1;</pre>
```

When you elaborate design Top with hdlin\_elab\_errors\_deep set to false (default behavior), Presto VHDL reports the first-level errors in sub1 (ELAB-368 and ELAB-306) but does not report the ELAB-368 error in submodule foo. Example 1-6 shows the session log.

#### Example 1-6

```
analyze -f vhdl test.vhd
Running PRESTO HDLC
Compiling Entity Declaration TOP
Compiling Architecture A1 of TOP
Compiling Entity Declaration SUB1
Compiling Architecture A1 of SUB1
Compiling Entity Declaration FOO
Compiling Architecture A1 of F00
Compiling Entity Declaration BAR
Compiling Architecture A1 of BAR
Compiling Entity Declaration SUB2
Compiling Architecture A1 of SUB2
Presto compilation completed successfully.
Loading db file '/.../lsi_10k.db'
elaborate top
Loading db file '/.../gtech.db'
Loading db file '/.../standard.sldb'
  Loading link library 'lsi_10k'
  Loading link library 'gtech'
Running PRESTO HDLC
Presto compilation completed successfully.
Elaborated 1 design.
Current design is now 'top'.
Information: Building the design 'sub1'. (HDL-193)
Error: ./test.vhd:39: Net 'temp', or a directly connected net, is driven
more than one source, and at least one source is a constant net.
(ELAB-368)
Error: ./test.vhd:40: Illegal use of tristate value (HDL-140).
(ELAB-306)
*** Presto compilation terminated with 2 errors. ***
Information: Building the design 'sub2'. (HDL-193)
Presto compilation completed successfully.
Warning: Unable to resolve reference 'sub1' in 'top'. (LINK-5)
current_design
Current design is 'top'.
{top}
list_design
sub2 top (*)
1
```

When you elaborate design Top with hdlin\_elab\_errors\_deep set to true, Presto VHDL reports errors across the hierarchy, as shown in Example 1-7.

#### **Important:**

Presto VHDL does not create designs when hdlin\_elab\_errors\_deep is set to true. If you run list\_design, Presto VHDL reports "Warning: No designs to list. (UID-275)"

#### Example 1-7

```
set hdlin_elab_errors_deep TRUE
analyze -f vhdl test.vhd
Running PRESTO HDLC
Compiling Entity Declaration TOP
Compiling Architecture A1 of TOP
Compiling Entity Declaration SUB1
Compiling Architecture A1 of SUB1
Compiling Entity Declaration FOO
Compiling Architecture A1 of F00
Compiling Entity Declaration BAR
Compiling Architecture A1 of BAR
Compiling Entity Declaration SUB2
Compiling Architecture A1 of SUB2
Presto compilation completed successfully.
Loading db file '/.../lsi_10k.db'
elaborate top
Loading db file '/.../gtech.db'
Loading db file '/.../standard.sldb'
  Loading link library 'lsi_10k'
  Loading link library 'gtech'
Running PRESTO HDLC
*** Presto compilation run in rtl debug mode. ***
Presto compilation completed successfully.
Elaborated 1 design.
Current design is now 'top'.
Information: Building the design 'sub1'. (HDL-193)
*** Presto compilation run in rtl debug mode. ***
Error: ./test.vhd:39: Net 'temp', or a directly connected net, is driven
more than one source, and at least one source is a constant net.
(ELAB-368)
Error: ./test.vhd:40: Illegal use of tristate value (HDL-140).
(ELAB-306)
*** Presto compilation terminated with 2 errors. ***
*** Presto compilation run with backup flow. ***
Information: Building the design 'sub2'. (HDL-193)
*** Presto compilation run in rtl debug mode. ***
Presto compilation completed successfully.
Information: Building the design 'foo'. (HDL-193)
*** Presto compilation run in rtl debug mode. ***
Error: ./test.vhd:60: Net 'temp', or a directly connected net, is driven
```

```
by
more than one source, and at least one source is a constant net.
(ELAB-368)

*** Presto compilation terminated with 1 errors. ***

*** Presto compilation run with backup flow. ***

Information: Building the design 'bar'. (HDL-193)

*** Presto compilation run in rtl debug mode. ***

Presto compilation completed successfully.

1

current_design

Error: Current design is not defined. (UID-4)

list_design

Warning: No designs to list. (UID-275)
```

The hdlin\_elab\_errors\_deep variable is designed to save you time in finding design elaboration and linking errors. For VHDL design Top, under default conditions, only the top-level errors are identified:

ELAB-368 and ELAB-306 in sub1

To find the ELAB-368 error in submodule foo, you need to fix all the errors in sub1 and elaborate again. However, if you set hdlin\_elab\_errors\_deep to true, all errors across the hierarchy are identified in one elaboration run. Presto VHDL reports

- ELAB-368 and ELAB-306 in sub1
- ELAB-368 in submodule foo

## hdlin\_elab\_errors\_deep FAQs

1. Why should I use the hdlin\_elab\_errors\_deep variable?

This variable enables Presto VHDL to report elaboration, linking, and VER-37 errors and warnings across hierarchical designs in a single elaboration run.

2. Why isn't the hdlin\_elab\_errors\_deep variable set to true by default?

If the variable were true by default, no designs could be saved. To prevent designs with errors from being propagated, Presto VHDL does not save designs when hdlin\_elab\_errors\_deep is set to true.

3. Why can't Presto VHDL save only the designs that don't have errors when hdlin elab errors deep is set to true?

When hdlin\_elab\_errors\_deep is set to true, Presto VHDL elaborates lower-level designs even if the top-level design has errors. Occasionally, errors in the top level cause lower-level errors that are not reported; the lower-level appears to be error free, but isn't.

4. What types of errors does hdlin\_elab\_errors\_deep report?

ELAB errors and warnings, LINK errors and warnings, and the VER-37 internal error.

5. How does Presto VHDL handle parameterized designs that do not have parameters specified?

Presto VHDL reports these as errors during analyze.

6. Why do I have to fix my syntax errors before elaborating?

After doing analyze, Presto VHDL creates an intermediate design that the elaborate command uses to elaborate the design. This intermediate file is created only after all syntax errors are fixed. If you do not fix all the syntax errors, there is no intermediate file to elaborate.

7. I want to use the read\_file command. What happens if I set hdlin\_elab\_errors\_deep to true and use read\_file?

The read\_file command is not supported for use with hdlin\_elab\_errors\_deep because read\_file does not include the functionality of the link command. The elaborate command includes the functionality of the link command. The read\_file command does not allow command-line parameter specification; the elaborate command allows this.

- 8. How much longer does elaboration take when I set hdlin\_elab\_errors\_deep to true? There is a very small increase in elaboration time.
- 9. Does capacity drop when I set hdlin\_elab\_errors\_deep to true? Is there a recommended number of errors I can tell Presto VHDL to stop at? If I have lots of errors, will it hang?

No noticeable difference in performance has been noted.

10. Can I compile when hdlin\_elab\_errors\_deep is true?

No design is created when hdlin\_elab\_errors\_deep is true. Even if the design appears to be error free, no design will be created. You cannot compile because there is no design to compile.

- 11. When hdlin\_elab\_errors\_deep is true, will all errors be valid? In most cases, all reported errors are valid.
- 12. The hdlin\_elab\_errors\_deep command seems like a very helpful feature. Why didn't you do it earlier?

Designs are getting bigger and to accommodate these larger designs, more hierarchy is being created. Thus the need for hdlin\_elab\_errors\_deep developed over time.

13. Can I use the -clock\_gate option with the elaborate command when hdlin\_elab\_errors\_deep is true?

- No. You cannot create clock gating with the elaborate -clock\_gating command. The tool will error out.
- 14.Can I get incorrect logic when using hdlin\_elab\_errors\_deep?
  - No, because a design is not created.
- 15. Is hdlin elab errors deep a lint tool?
  - No, Presto VHDL does not include a lint tool. The Design Compiler tool provides the check\_design command, which provides the lint function.
- 16. What happens if I set hdlin\_elab\_errors\_deep to true and analyze a design with syntax errors?

The syntax errors are reported (same as default behavior).

17. What happens when I have multiple instances of erroneous designs when hdlin\_elab\_errors\_deep is true?

There is no behavior change. Presto VHDL reports ELAB errors when elaborating the design (module declaration), not the instantiation. The error messages do not get multiplied by the number of instances. This is the same as the default behavior.

- 18.Does Presto VHDL report all syntax errors when I use the analyze command? Are all syntax errors reported at once, or do I need to do multiple analyze commands?
  - One analyze command reports all the syntax errors.
- 19. What happens if I read in some designs and later set the hdlin\_elab\_errors\_deep variable to true?

Previously read-in designs will still be in memory, but it is better to remove the designs before setting hdlin elab errors deep to true.

## **Parameterized Models (Generics)**

Presto VHDL fully supports generic declarations. Generics enable you to assign unique parameter values to each model instance when you elaborate your design.

The model in Example 1-8 uses a generic declaration to determine the bit-width of a register input; the default width is declared as 2.

#### Example 1-8 Generic Register Model

```
LIBRARY IEEE, SYNOPSYS;
USE IEEE.STD_LOGIC_1164.ALL;
USE IEEE.STD_LOGIC_ARITH.ALL;
USE IEEE.STD_LOGIC_MISC.ALL;
USE SYNOPSYS.ATTRIBUTES.ALL;
```

```
entity DFF is
generic(N : INTEGER := 2); --flip flop is N bits wide
 port(input : in STD_LOGIC_VECTOR (N - 1 downto 0);
     clock : in STD_LOGIC;
     output : out STD_LOGIC_VECTOR (N - 1 downto 0) );
end DFF;
architecture RTL of DFF is
begin
entry : process (clock)
  variable tmp: STD_LOGIC_VECTOR (N - 1 downto 0);
 if (clock = '0') then
   tmp := input;
 else
   if (clock = '1') then
     output <= tmp;</pre>
   end if;
 end if;
end process;
end RTL;
```

To analyze the model in Example 1-8 on page 1-17 and store the analyzed results in a user-specified design library, mylib, use the analyze command with the <code>-library</code> option, as follows (assume that the file name for the model in Example 1-8 on page 1-17 is n-register.vhd.):

```
dc_shell-t> analyze -format vhdl n-register.vhd -library
mylib
```

If you want an instance of the register model to have a bit-width of 3, use the elaborate command to specify this as follows:

```
dc_shell-t> elaborate DFF -parameters N=3
```

The list\_designs command shows the design, as follows:

```
dc_shell-t> list_designs
  Design
-----
* DFF N3
```

Using the read command with generics is not recommended, because you can build only the default value of the generic. If you do not specify a default generic value, Presto VHDL reports the following:

```
Warning: filename:line: Generic N does not have default value. (\texttt{ELAB-943}).
```

In addition, you need to either set the variable hdlin\_auto\_save\_templates to true or insert the --synopsys template directive in the entity declaration, as follows:

```
entity DFF is
generic(N : INTEGER := 2); --flip flop is N bits wide
port(input : in STD_LOGIC_VECTOR (N - 1 downto 0);
      clock : in STD_LOGIC;
      output : out STD_LOGIC_VECTOR (N - 1 downto 0) );
    -- synopsys template
end DFF;
```

The variables described in Table 1-5 control the naming of designs based on generic models. To list their current values, enter the following:

```
dc_shell-t> printvar template_*
```

Table 1-5 Template Naming Variables

| Variable                 | Description                                                                                                                                                                                                                                                                                                                                              |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| template_naming_style    | Controls how templates (VHDL generics) are named. The default value is %s_%p, where %s is the name of the source design and %p is the parameter list. By default, the design name and the parameter list are separated by an underscore (_). The naming style for the parameter list is the value of the template_separator_style variable.              |
| template_separator_style | Provides a separator character for multiple parameters in a template name. The default value is an underscore (_).                                                                                                                                                                                                                                       |
| template_parameter_style | Controls how template parameters are named. The default value is %s%d, where %s is the name of a parameter and %d is the value of that parameter. By default, the parameter name and value are not separated. If there are two or more parameters, each parameter name or value pair is separated by the value of the template_separator_style variable. |

# **Configuration Support**

To enable configuration support, set hdlin\_enable\_configurations to true (default is false).

Configurations bind entity design units to architecture design units. To specify a configuration, you must use the analyze command. For example, if file.vhdl contains the configuration my configuration, read the design as follows:

```
analyze -f vhdl file.vhdl
elaborate my_configuration
```

Although VHDL allows different entities to have different architecture definitions of the same name, for example,

```
arch RTL1 of entity1 is
....
arch RTL1 of entity2 is
```

the same does not hold for configurations, for example,

```
configuration CNFG1 of entity1 is \dots configuration CNFG1 of entity2 is
```

is not supported. Presto VHDL binds the last read definition of CNFG1 to both entities. Therefore, configuration names for different entities must be unique. There is no configuration/entity pair concept. If configurations for different entities have the same name and they are analyzed sequentially, only the last one remains.

```
entity conf_0_vhdl is
    port(x: in BIT; y: out BIT);
end conf_0_vhdl;

architecture design_0_vhdl of conf_0_vhdl is
    begin
    y <= x;
end design_0_vhdl;

configuration trivial_config of work.conf_0_vhdl is
    for design_0_vhdl
    end for;
end trivial_config;</pre>
```

#### Example 1-10 shows the dc\_shell log output.

#### Example 1-10

```
dc_shell> elaborate trivial_config
Running PRESTO HDLC
Loading db file '/SYNOPSYS_ROOT_DIRECTORY/libraries/syn/standard.sldb'
Loading db file '/SYNOPSYS_ROOT_DIRECTORY/libraries/syn/gtech.db'
Loading db file '/SYNOPSYS_ROOT_DIRECTORY/libraries/syn/lsi_10k.db'
format: vhdl
Presto compilation completed successfully.
Current design is now 'conf_0_vhdl'
```

#### This following subsections describe Presto VHDL support for configurations:

- Example 1: Bind Entity to Architecture
- Example 2: Use Architectures From the Same Library
- Example 3: Use Architectures From Different Libraries
- Example 4: Configuration With a Component Inside a Concurrent Block
- Example 5: Generic in a Configuration
- Example 6: Port Map in a Configuration
- Example 7: Nested Configurations
- Example 8: Indirectly Nested Configurations
- Example 9: Embedded Configurations
- Example 10: Multiple Architectures in Embedded Configurations Last Chosen as Default
- Example 11: Combinations of Embedded, Nested, and Stand-Alone Configurations Require Elaborate with a Configuration Identifier

# **Example 1: Bind Entity to Architecture**

Example 1-11 uses configurations to bind components C1 and C2 to specific entity/ architecture combinations.

```
entity a_bar_b is
  port(a, b: in bit; c: out bit);
end a_bar_b;

architecture struct of a_bar_b is
  begin
        c <= not(a) and b;
end struct;</pre>
```

```
entity a_b_bar is
  port(a, b: in bit; c: out bit);
end a_b_bar;
architecture struct of a_b_bar is
  begin
     c <= a and not(b);
end struct;
entity conf_1_vhdl is
   port(a, b: in bit; c: out bit);
end conf_1_vhdl;
architecture struct of conf_1_vhdl is
     component a_bar_b port(a, b: in bit; c :out bit); end component;
    component a_b_bar port(a, b: in bit; c :out bit); end component;
     signal a_not_b, not_a_b: bit;
       begin
            C1: a_bar_b port map(a, b, not_a_b);
            C2: a_b_bar port map(a, b, a_not_b);
            c <= not_a_b or a_not_b;
end struct;
configuration config_example1 of conf_1_vhdl is
    for struct -- of conf_1_vhdl
      for C1: a_bar_b
         use entity work.a_bar_b(struct);
      end for;
      for C2: a_b_bar
          use entity work.a_b_bar(struct);
      end for;
   end for;
end config_example1;
```

Example 1-12 shows the dc\_shell log output.

```
dc_shell> elaborate config_example1
Running PRESTO HDLC
Loading db file '/SYNOPSYS_ROOT_DIRECTORY/libraries/syn/standard.sldb'
Loading db file '/SYNOPSYS_ROOT_DIRECTORY/libraries/syn/gtech.db'
Loading db file '/SYNOPSYS_ROOT_DIRECTORY/libraries/syn/lsi_10k.db'
Component WORK.STRUCT/CONF_1_VHDL.STRUCT.C1 has been configured to use the
following implementation:
    Work Library: WORK
    Design Name: A_BAR_B
    Architecture Name: STRUCT
Component WORK.STRUCT/CONF_1_VHDL.STRUCT.C2 has been configured to use the
following implementation:
    Work Library: WORK
    Design Name: A_B_BAR
```

```
Architecture Name: STRUCT
Presto compilation completed successfully.
Information: Building the design 'A_BAR_B'. (HDL-193)
Running PRESTO HDLC
Presto compilation completed successfully.
Information: Building the design 'A_B_BAR'. (HDL-193)
Running PRESTO HDLC
Presto compilation completed successfully.
Current design is now 'conf_1_vhdl'
```

# **Example 2: Use Architectures From the Same Library**

Example 1-13 uses configurations to bind two instances of the same component to different architectures of same entity. The component C1 is implemented using architecture struct1, while C2 is implemented using architecture struct2.

```
entity a_bar_b is
    port(a, b: in bit; c: out bit);
end a_bar_b;
architecture struct1 of a_bar_b is
    c <= not(a) and b;
end struct1;
architecture struct2 of a bar b is
begin
   c <= a and not(b);
end struct2;
entity conf 2 vhdl is
    port(a, b: in bit; c: out bit);
end conf_2_vhdl;
architecture struct of conf_2_vhdl is
    component a_bar_b port(a, b: in bit; c :out bit); end component;
    signal a_not_b, not_a_b: bit;
begin
    C1: a_bar_b port map(a, b, not_a_b);
    C2: a_bar_b port map(a, b, a_not_b);
    c <= not a b or a not b;
end struct;
configuration config_example2 of conf_2_vhdl is
    for struct -- of conf_2_vhdl
        for C1: a_bar_b
```

```
use entity work.a_bar_b(struct1);
end for;
for C2: a_bar_b
     use entity work.a_bar_b(struct2);
end for;
end for;
end config_example2;
```

#### Example 1-14 shows the dc shell log output.

#### Example 1-14

```
dc_shell> elaborate config_example2
Running PRESTO HDLC
Loading db file '/SYNOPSYS ROOT DIRECTORY/libraries/syn/standard.sldb'
Loading db file '/SYNOPSYS_ROOT_DIRECTORY/libraries/syn/gtech.db'
Loading db file '/SYNOPSYS ROOT DIRECTORY/libraries/syn/lsi 10k.db'
Component WORK.STRUCT/CONF 2 VHDL.STRUCT.C1 has been configured to use
following implementation:
      Work Library: WORK
      Design Name: A_BAR_B
      Architecture Name: STRUCT1
Component WORK.STRUCT/CONF 2 VHDL.STRUCT.C2 has been configured to use
the
following implementation:
     Work Library: WORK
     Design Name: A_BAR_B
     Architecture Name: STRUCT2
Presto compilation completed successfully.
Information: Building the design 'A_BAR_B'. (HDL-193)
Running PRESTO HDLC
Presto compilation completed successfully.
Information: Building the design 'A_BAR_B'. (HDL-193)
Running PRESTO HDLC
Presto compilation completed successfully.
Current design is now 'conf_2_vhdl'
```

# **Example 3: Use Architectures From Different Libraries**

Example 1-15 on page 1-25 shows how to use a configuration to do the following:

- Bind architecture struct1 in library lib1 to an instantiation C1 of component a\_bar\_b
- Bind architecture struct2 in library lib2 to an instantiation C2 of component a\_bar\_b

```
--File config3.1.vhdl
 entity a_bar_b is
    port(a, b: in bit; c: out bit);
end a_bar_b;
architecture struct1 of a_bar_b is
    c \le not(a) and b;
end struct1;
File config3.2.vhdl
entity a_bar_b is
    port(a, b: in bit; c: out bit);
end a_bar_b;
architecture struct2 of a_bar_b is
    c <= a and not(b);
end struct2;
--File config3.3.vhdl
library lib1, lib2;
use lib1.all;
use lib2.all;
entity conf_3_vhdl is
    port(a, b: in bit; c: out bit);
end conf_3_vhdl;
architecture struct of conf_3_vhdl is
    component a_bar_b port(a, b: in bit; c :out bit); end component;
    signal a_not_b, not_a_b: bit;
begin
    C1: a_bar_b port map(a, b, not_a_b);
    C2: a_bar_b port map(a, b, a_not_b);
    c <= not_a_b or a_not_b;</pre>
end struct;
configuration config_example3 of conf_3_vhdl is
    for struct -- of conf_3_vhdl
        for C1: a_bar_b
            use entity lib1.a_bar_b(struct1);
        end for;
        for C2: a_bar_b
            use entity lib2.a_bar_b(struct2);
        end for;
```

```
end for;
end config_example3;
```

#### Example 1-16 shows the script file.

#### Example 1-16

```
sh mkdir ./lib1
sh mkdir ./lib2
define_design_lib lib1 -path ./lib1
define_design_lib lib2 -path ./lib2

analyze -f vhdl config3.1.vhdl -lib lib1
analyze -f vhdl config3.2.vhdl -lib lib2
analyze -f vhdl config3.3.vhdl
elaborate config_example3
```

#### Example 1-17 shows the dc\_shell log output.

```
dc_shell> analyze -f vhdl config3.1.vhdl -lib lib1
Running PRESTO HDLC
Input files:
/TEST_DIRECTORY/config3.1.vhdl
Compiling Entity Declaration A_BAR_B
Compiling Architecture STRUCT1 of A_BAR_B
Presto compilation completed successfully.
dc_shell> analyze -f vhdl config3.2.vhdl -lib lib2
Running PRESTO HDLC
Input files:
config3.2.vhdl
Compiling Entity Declaration A_BAR_B
Compiling Architecture STRUCT2 of A_BAR_B
Presto compilation completed successfully.
dc_shell> analyze -f vhdl config3.3.vhdl
Running PRESTO HDLC
Input files:
config3.3.vhdl
Compiling Entity Declaration CONF_3_VHDL
Compiling Architecture STRUCT of CONF_3_VHDL
Compiling Configuration CONFIG_EXAMPLE3 of CONF_3_VHDL
Presto compilation completed successfully.
dc_shell> elaborate config_example3
Running PRESTO HDLC
Loading db file '/SYNOPSYS_ROOT_DIRECTORY/libraries/syn/standard.sldb'
Loading db file '/SYNOPSYS_ROOT_DIRECTORY/libraries/syn/gtech.db'
Loading db file '/SYNOPSYS_ROOT_DIRECTORY/libraries/syn/lsi_10k.db'
Component WORK.STRUCT/CONF_3_VHDL.STRUCT.C1 has been configured to use
the
following implementation:
```

```
Work Library: LIB1
     Design Name: A_BAR_B
     Architecture Name: STRUCT1
Component WORK.STRUCT/CONF_3_VHDL.STRUCT.C2 has been configured to use
following implementation:
     Work Library: LIB2
     Design Name: A_BAR_B
     Architecture Name: STRUCT2
Presto compilation completed successfully.
Information: Building the design 'A_BAR_B'. (HDL-193)
Running PRESTO HDLC
Presto compilation completed successfully.
Information: Building the design 'A_BAR_B'. (HDL-193)
Running PRESTO HDLC
Presto compilation completed successfully.
Current design is now 'conf_3_vhdl'
```

# **Example 4: Configuration With a Component Inside a Concurrent Block**

Example 1-18 shows how to configure a component inside a concurrent block.

```
entity my_or is
port (a, b: bit; z:out bit);
end entity my_or;
architecture beh of my or is
begin
 z <= a or b;
end;
entity conf_4_vhdl is
  port(A, B: BIT; Z: out BIT);
end;
architecture BEH of conf 4 vhdl is
  component MY_AND
    port(A, B: BIT;
         Z: out BIT);
  end component;
begin
  Z \ll A;
  L1: for I in 3 downto 0 generate
    L2: for J in I downto 0 generate
      L3: if J < I generate
```

```
U1: MY AND port map (A, B, Z);
      end generate;
    end generate;
  end generate;
end;
configuration config example4 of conf 4 vhdl is
    for beh
        for L1
          for L2
            for L3
              for U1: MY_AND
                use entity work.my_or (beh);
              end for;
            end for;
          end for;
        end for;
    end for;
end config example4;
```

#### Example 1-19 shows the dc shell log output.

```
dc_shell> elaborate config_example4
Running PRESTO HDLC
Loading db file '/SYNOPSYS_ROOT_DIRECTORY/libraries/syn/standard.sldb'
Loading db file '/SYNOPSYS_ROOT_DIRECTORY/libraries/syn/gtech.db'
Loading db file '/SYNOPSYS ROOT DIRECTORY/libraries/syn/lsi 10k.db'
Component WORK.BEH/CONF 4 VHDL.BEH.L1.L2.L3.U1 has been configured to use
the
following implementation:
      Work Library: WORK
     Design Name: MY_OR
      Architecture Name: BEH
Presto compilation completed successfully.
Information: Building the design 'MY_OR'. (HDL-193)
Running PRESTO HDLC
Presto compilation completed successfully.
Current design is now 'conf_4_vhdl'
```

## **Example 5: Generic in a Configuration**

Example 1-20 shows a component configuration used with a generic. Notice that the MY\_AND component is configured to use the MY\_OR (width = 8) implementation.

```
entity my_or is
generic (width : integer);
port (a, b: in bit_vector (width - 1 downto 0);
         z: out bit_vector (width - 1 downto 0));
end entity my_or;
architecture beh of my_or is
begin
  z <= a or b;
end;
entity conf_5_vhdl is
  port(A, B: in BIT_VECTOR (7 downto 0);
        Z: out BIT_VECTOR (7 downto 0));
end;
architecture BEH of conf_5_vhdl is
  component MY_AND
    generic (width: integer := 5);
   port(A, B: in BIT VECTOR (width - 1 downto 0);
         Z: out BIT_VECTOR (width - 1 downto 0));
  end component;
begin
  Z \ll A;
  L1: for I in 3 downto 0 generate
        U1: MY_AND port map (A, B, Z);
  end generate;
end;
configuration config_example5 of conf_5_vhdl is
    for beh
        for L1
            for U1: MY_AND
              use entity work.my_or (beh) generic map (width => 8);
            end for:
        end for;
    end for;
end config_example5;
```

Example 1-21 shows the dc shell log output.

#### Example 1-21

```
dc_shell> elaborate config_example5
     Running PRESTO HDLC
     Loading db file '/SYNOPSYS_ROOT_DIRECTORY/libraries/syn/
standard.sldb'
     Loading db file '/SYNOPSYS_ROOT_DIRECTORY/libraries/syn/gtech.db'
     Loading db file '/SYNOPSYS_ROOT_DIRECTORY/libraries/syn/lsi_10k.db'
     Component WORK.BEH/CONF_5_VHDL.BEH.L1.U1 has been configured to use
following implementation:
           Work Library: WORK
           Design Name: MY_OR
           Architecture Name: BEH
     Presto compilation completed successfully.
     Information: Building the design 'MY_OR' instantiated from design
'conf_5_vhdl' with the parameters "width=8". (HDL-193)
     Running PRESTO HDLC
     Presto compilation completed successfully.
     Current design is now 'conf_5_vhdl'
```

### **Example 6: Port Map in a Configuration**

Example 1-22 uses a port map in the configuration.

```
library ieee;
use ieee.std_logic_1164.all;
use std.standard.time;
entity INVERTER is
port (IN1 : in BIT; OUT1 : out BIT);
end INVERTER;
architecture STRUCT_I of INVERTER is
 begin
      out1 <= not in1;
  end STRUCT I;
entity CONFIG_TEST1_VHDL is end CONFIG_TEST1_VHDL;
architecture STRUCT_T of CONFIG_TEST1_VHDL is
  signal S1, S2 : BIT := '1';
component INV_COMP is
  port (IN_A : in BIT; OUT_A : out BIT);
end component;
  begin
     lh : inv_comp port map (S1, S2);
```

```
end STRUCT_T;

configuration CONFIG_INV of CONFIG_TEST1_VHDL is
for STRUCT_T
  for LH : INV_COMP
    use entity WORK.INVERTER (STRUCT_I)
    generic map (PropTime => TimeH)
    port map (IN1 => IN_A, OUT1 => OUT_A);
  end for;
end for;
end CONFIG_INV;
```

# **Example 7: Nested Configurations**

Example 1-23 uses a configuration inside a configuration.

```
entity MY_AND is
end entity MY_AND;
architecture STRUCT1 of MY_AND is
begin
O \ll A and B;
end STRUCT1;
entity MY_XOR is
end entity MY_XOR;
architecture STRUCT1 of MY_XOR is
component MY_AND is
port (A, B : in bit;
     O: out bit);
end component;
begin
 U1: MY_AND port map (A, B, O);
end STRUCT1;
architecture STRUCT2 of MY_XOR is
signal S1, S2, S3, S4 : bit;
begin
S1 \ll A and (not B);
S2 \ll (not A) and B;
0 <= S1 or S2;</pre>
```

```
end STRUCT2;
entity CONFIG_FLOW_VHDL is
port (A1, A2, A3, A4, A5, B1, B2, B3, B4, B5 : in bit;
     01, 02, 03, 04, 05
                                               : out bit);
end CONFIG FLOW VHDL;
architecture A1 of CONFIG_FLOW_VHDL is
component MY_XOR_COM is
port (A, B: in bit;
      0
               : out bit);
end component;
component MY_AND is
end component ;
begin
U1 : MY_XOR_COM port map (A1, B1, O1);
U2 : MY_XOR_COM port map (A2, B2, O2);
U3 : MY_XOR_COM port map (A3, B3, O3);
U4 : MY_XOR_COM port map (A4, B4, O4);
V1 : MY_AND port map (A5, B5, O5);
end A1;
configuration TEST_CONFIG of MY_XOR is
  for STRUCT1
   for U1: MY_AND
     use entity WORK.MY AND;
   end for;
  end for;
end TEST_CONFIG;
configuration MY CONFIG of CONFIG FLOW VHDL is
use WORK.all;
for A1
  for U1, U2 : MY_XOR_COM
    use entity WORK.MY_XOR (STRUCT1);
  end for;
  for U3 : MY XOR COM
   use entity WORK.MY_XOR (STRUCT2);
  end for;
  for U4 : MY_XOR_COM
    use configuration WORK.TEST_CONFIG;
  end for;
  for V1 : MY AND
     -- Use default
  end for;
end for;
end MY_CONFIG;
```

# **Example 8: Indirectly Nested Configurations**

A directly nested configuration is a nested configuration that configures its subdesign by using a "use configuration subconfigure" clause, as shown in Example 1-24; an indirectly nested configuration is a nested configuration that configures its subdesign by using a "for" clause, as shown in Example 1-25.

#### Example 1-24 Directly Nested Configuration

```
configuration conf_in_conf_configuration of conf_in_conf is
   for test
      for all : conf_test
        use configuration WORK.TEST_CONFIG; -- nested configuration
      end for;
   end for;
end conf in conf configuration;
```

#### Example 1-25 Indirectly Nested Configuration

# **Example 9: Embedded Configurations**

The Presto VHDL tool supports embedded configurations. To enable this feature, set hdlin\_enable\_configurations to true. Example 1-26 shows an embedded configuration.

#### Example 1-26 Embedded Configuration

```
architecture Structure of Test_Bench is
                component Buf is
                                port (Comp_I: in Bit; Comp_O: out Bit);
                end component;
                -- A binding indication; generic and port map aspects
within a
                -- binding indication associate actuals (Comp_I, etc.)
with
                -- formals of the entity declaration (Input pin, etc.):
                for UUT: Buf
                                use entity Work.Buf(DataFlow)
                                port map (Input_pin => Comp_I,
Output_pin=> Comp_O);
                signal S1, S2: Bit;
begin
                -- A component instantiation statement; generic and port
map aspects
                -- within a component instantiation statement associate
actuals
                -- (S1, etc.) with the formals of a component (Comp_I,
etc.):
                UUT: Buf
                                port map (Comp_I => S1, Comp_O => S2);
                -- A block statement; generic and port map aspects within
the
                -- block header of a block statement associates actuals
(in this
                -- case, 4, with the formals defined in the block header:
                B: block
                begin
                end block;
end Structure;
```

You can use an embedded configuration in only one **for** construct in one component, as shown in Example 1-27. However, as a stand-alone configuration, you can use embedded configurations in multi-nested configurations and in several **for** key words, as shown in Example 1-28.

#### Example 1-27 Embedded Configuration

```
for u1: embed_shift use entity work.embed_shift;
```

#### Example 1-28 Standalone Configuration

configuration embed top config of embed top is

```
for arch1
    for swap_exp1 : work.components.swap_exp
        use entity work.swap_exp(comb_seq)
        generic map (width1 => width + 1);
for comb_seq
    for seq_gen
        for all: work.components.sync_async
        use entity work.sync_async(sync_logic)
        generic map (width2 => width1 + 1);
```

To read designs with embedded configurations, use the standard VHDL reading methods of read\_vhld plus link or analyze and elaborate using the entity name. To help understand how the tool processes embedded configurations, consider the design in Example 1-29. When you read the RTL using read\_vhdl and link, the tool creates the log shown in Example 1-30; if you use analyze and elaborate, the tool creates the log shown in Example 1-31.

#### Note:

If you have multiple embedded architectures, you need to follow the usage guidelines described in "Example 10: Multiple Architectures in Embedded Configurations - Last Chosen as Default" on page 1-37.

#### Example 1-29 Module config\_simple\_embed.vhd

```
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
entity embed_shift is
 generic (width: integer := 4);
 port (
  a : in bit_vector(0 to width - 1);
 b : in integer;
       o : out bit_vector(0 to width - 1)
 );
end entity embed_shift;
architecture tmp1 of embed_shift is
begin
   o <= a sll b;
end architecture tmp1;
entity mix_embed_config is
 port (
  a : in bit_vector(0 to 7);
 b : in integer;
        o : out bit_vector(0 to 7)
 );
end entity mix_embed_config;
architecture tmp of mix_embed_config is
```

```
component my shift is
 generic (width: integer := 8);
 port (
 a : in bit_vector(0 to width - 1);
 b : in integer;
 o : out bit_vector(0 to width - 1)
 );
end component my_shift;
for u1: my_shift use entity work.embed_shift;
-- use an embedded configuration because the component name is different
than the
-- library name
begin
ul: my_shift
    port map (a, b, o);
end architecture tmp;
```

#### Example 1-30 Presto Report Log for read\_vhdl and link

```
dc_shell> read_vhdl config.support_embedded.config_2.vhd
Loading db file '.../libraries/syn/lsi 10k.db'
Loading db file '.../libraries/syn/gtech.db'
Loading db file '.../libraries/syn/standard.sldb'
  Loading link library 'lsi_10k'
  Loading link library 'gtech'
Loading vhdl file './config_simple_embed.vhd'
Running PRESTO HDLC
Compiling Entity Declaration EMBED_SHIFT
Compiling Architecture TMP1 of EMBED_SHIFT
Compiling Entity Declaration MIX_EMBED_CONFIG
Compiling Architecture TMP of MIX_EMBED_CONFIG
Component WORK.TMP/MIX_EMBED_CONFIG.TMP.U1 has been configured to use the
following
implementation:
      Work Library: WORK
      Design Name: EMBED_SHIFT
Presto compilation completed successfully.
Current design is now './embed_shift.db:embed_shift'
Loaded 2 designs.
Current design is 'embed_shift'.
embed_shift mix_embed_config
dc_shell> link
  Linking design 'embed_shift'
  Using the following designs and libraries:
______
 embed_snift ./embed_shift.db
lsi_10k (library) .../libraries/syn/lsi_10k.db
mix_embed_config ./mix_embed_confi
1
```

#### Example 1-31 Presto Report Log for Analyze and Elaborate With Entity Name

```
analyze -f vhdl config_simple_embed.vhd
Running PRESTO HDLC
Compiling Entity Declaration EMBED_SHIFT
Compiling Architecture TMP1 of EMBED_SHIFT
Compiling Entity Declaration MIX_EMBED_CONFIG
Compiling Architecture TMP of MIX EMBED CONFIG
Presto compilation completed successfully.
elaborate mix_embed_config
Loading db file '.../libraries/syn/gtech.db'
Loading db file '.../libraries/syn/standard.sldb'
  Loading link library 'gtech'
Running PRESTO HDLC
Component WORK.TMP/MIX_EMBED_CONFIG.TMP.U1 has been configured to use the
following
implementation:
     Work Library: WORK
     Design Name: EMBED SHIFT
Presto compilation completed successfully.
Elaborated 1 design.
Current design is now 'mix_embed_config'.
Information: Building the design 'EMBED_SHIFT' instantiated from design
'mix_embed_config'
with
     the parameters "width=8". (HDL-193)
Presto compilation completed successfully.
```

# Example 10: Multiple Architectures in Embedded Configurations - Last Chosen as Default

If you have multiple architectures defined for an entity and you instantiate that entity without a specific binding to a specific architecture, the tool chooses the last architecture that is read as the architecture for that entity. Consider Example 1-32 on page 1-38 in which the MY\_AND entity is instantiated by the U2 component. The tool by default will associate the last architecture read, STRUCT4, with U2 and generate a warning shown in Example 1-33 on page 1-38.

To avoid this warning, you need to tell the tool which architecture to choose by specifying the binding in the embedded configuration. If you have several nested designs, you can create a stand-alone configuration to connect the correct working library(s) to the appropriate components/configurations. In Presto, you can select a configuration identifier and use it to elaborate. To insure your design intent is correctly read, elaborate with the configuration identifier, as described in the next section.

#### Example 1-32 Default Architecture for U2 Component is STRUCT4

```
entity MY_AND is
  port (0 : out bit);
end entity MY_AND;
architecture STRUCT3 of MY_AND is
begin
 0 <= '1';
end STRUCT3;
architecture STRUCT4 of MY_AND is
begin
 0 <= '0';
end STRUCT4;
entity E1 is
 port (0 : out bit);
end E1;
architecture A1 of E1 is
                        -- same name as a previously found entity
  component MY_AND is
   port(0 : out bit);
  end component;
begin
 U2 : MY_AND port map (0);
end A1;
```

#### Example 1-33 Tool Warns When Multiple Architectures are Associated With an Entity

```
dc_shell> read_vhdl test.vhd
Loading db file '.../libraries/syn/gtech.db'
Loading db file '.../libraries/syn/standard.sldb'
  Loading link library 'gtech'
Loading vhdl file '.../test.vhd'
Running PRESTO HDLC
Compiling Entity Declaration MY_AND
Compiling Architecture STRUCT3 of MY_AND
Compiling Architecture STRUCT4 of MY_AND
Compiling Entity Declaration E1
Compiling Architecture A1 of E1
Warning: The entity 'MY_AND' has multiple architectures defined. The
last defined
architecture 'STRUCT4' will be used to build the design by default.
Presto compilation completed successfully.
Current design is now './MY AND.db:MY AND'
Loaded 2 designs.
Current design is 'MY_AND'.
MY AND E1
```

# Example 11: Combinations of Embedded, Nested, and Stand-Alone Configurations Require Elaborate with a Configuration Identifier

In order for the tool to correctly read your design when it contains a combination of embedded, nested, and stand-alone configurations, you must elaborate with the configuration identifier instead of with the entity name. To help understand this requirement, consider the design in Example 1-35 through Example 1-39 on page 1-43. In this design, if you want the tool to select the "swap\_seq of swap\_exp" architecture, you must elaborate the design using the configuration identifier, as shown in Example 1-34.

Example 1-34 Correct Way to Read the Design with Embedded, Nested, and Stand-Alone Configurations - Use the Configuration Identifier

```
analyze -f vhdl config_nested_sync_async.vhd
analyze -f vhdl config_nested_swap_exp.vhd
analyze -f vhdl embed_nested_standalone_top.vhd
elaborate embed_top_config
write -f ddc -h -o t.ddc
...
```

If you elaborate with the entity name (or use <code>read\_vhd1</code>), the tool chooses the last defined architecture it sees, which is "comb\_seq of swap\_exp" for this design. The tool does not see the configuration defined in embed\_nest\_standalone\_top.vhd. When you use the configuration identifier (embed\_top\_config) to elaborate, the tool reads both the architecture and configuration code and will use the embedded and standalone configuration's declarations for its library and it will choose the correct components.

#### Example 1-35 Top Module in embed nest standalone top.vhd

```
architecture arch1 of embed top is
     signal tmp_data1, tmp_data2 : std_logic_vector(0 to width);
     for swap_exp2 : work.components.swap_exp use entity
work.swap_exp(swap_seq)
generic map (width1 => 3);
begin
     swap_exp1 : component work.components.swap_exp
        port map (clk => clk, rst => rst, din1 => din, din2 => d2, dout
=> tmp_data1);
     swap_exp2 : component work.components.swap_exp
        port map (clk => clk, rst => rst, din1 => tmp data1, din2 => d2,
tmp_data2);
     swap_exp3 : component work.components.swap_exp
        port map (clk => clk, rst => rst, din1 => tmp_data2, din2 => d2,
dout => dout);
end architecture arch1;
configuration embed_top_config of embed_top is
   for arch1
       for swap_exp1 : work.components.swap_exp
        use entity work.swap_exp(comb_seq) generic map (width1 => width +
1);
        for comb_seq
            for seg gen
                for all: work.components.sync_async
              use entity work.sync_async(sync_logic) generic map (width2
=> width1
+ 1);
              for sync_logic
                for next_level : work.components.and_or
                    use entity work.and_or(and_of_logic);
              end for;
              end for;
            end for;
        end for;
       end for;
-- for swap_exp2 : is simple so it embeds on architecture
       -- for sawp_exp3 : work.components.sync_async
      -- use entity work.sync_async(comb_seq);
       for swap_exp3 : work.components.swap_exp
        use entity work.swap exp(comb seq);
        for comb_seq
            for seg gen
                for all : work.components.sync_async
```

```
use entity work.sync_async(async_logic);
        end for;
        end for;
```

#### Example 1-36 Sub-module in config nested swap exp.vhd

```
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
library work;
use work.components.all;
entity swap_exp is
     -- generic (width1 : integer := 4);
     generic (width1 : integer := 3);
     port (clk : in std_logic;
           rst : in std logic;
           din1 : in std_logic_vector(0 to width1 - 1);
           din2 : in std_logic_vector(0 to width1 - 1);
           dout : out std_logic_vector(0 to width1 - 1));
end entity swap_exp;
architecture swap_seq of swap_exp is
signal int_data : std_logic_vector (0 to width1 - 1);
begin
     swap : process (din1) is
     begin
        int data(2) <= din1(0);
        int_data(1) <= din1(1);
        int_data(0) <= din1(2);</pre>
     end process swap;
     seq : process (clk, rst) is
     begin
        if clk'event and clk = '1' then
           if (rst = '0') then
               -- dout <= 0;
               dout <= (others => '0');
               dout <= int data;</pre>
           end if;
        end if;
     end process seq;
end architecture swap_seq;
architecture comb_seq of swap_exp is
signal int_data : std_logic_vector (0 to 3);
begin
```

```
comb : process (din1, din2) is
          begin
             int_data(2) <= not(din1(0) or din2(0));</pre>
             int_data(1) <= din1(2) xor din2(1);</pre>
             int_data(0) <= din1(1) and din2(2);</pre>
          end process comb;
          -- seq_gen: for i in 0 to 3 generate
          seq_gen: for i in 0 to 2 generate
          begin
                reg : component work.components.sync_async
                port map (clk => clk, rst => rst, d1 => int_data(i), d2 =>
    int data(i),
    q => dout(i));
          end generate seq_gen;
    end architecture comb_seq;
Example 1-37 Sub-Module in config_nested_sync_async.vhd
    library ieee;
    use ieee.std logic 1164.all;
    use ieee.std_logic_unsigned.all;
    entity sync_async is
          generic (width2 : integer := 8);
          port (clk : in std_logic;
                 rst : in std_logic;
                 d1 : in std_logic;
                d2 : in std_logic;
                 q : out std_logic);
    end entity sync_async;
    architecture sync_logic of sync_async is
         signal tmp_data1, tmp_data2 : std_logic_vector(0 to width2-1);
         begin
          next_level : component work.components.and_or
              port map (a \Rightarrow d1, b \Rightarrow d2, o \Rightarrow tmp data1(0));
          reg: process (clk, rst) is
          begin
             if (clk'event and clk ='1') then
                if (rst = '0') then
                   q <= '0';
                else
                   q <= tmp_data1(0);</pre>
                end if;
             end if;
          report ("in SYNC");
          end process reg;
    end architecture sync_logic;
```

```
architecture async logic of sync async is
        signal tmp_data1, tmp_data2 : std_logic_vector(0 to width2-1);
        begin
          process (clk, rst) is
          begin
             if rst = '0' then
                q <= '0';
             elsif clk'event and clk = '1' then
                q \ll d1;
             end if;
          report ("in ASYNC");
          end process;
    end architecture async_logic;
Example 1-38 Sub-module in config_nested_and_or.vhd
    library ieee;
    use ieee.std_logic_1164.all;
    use ieee.std_logic_unsigned.all;
    entity and_or is
          port (a : in std_logic;
                b : in std_logic;
                o : out std_logic);
    end entity and_or;
    architecture and_of_logic of and_or is
          begin
             o \ll a and b;
    end architecture and_of_logic;
    architecture or_of_logic of and_or is
          begin
             o <= a or b;
    end architecture or_of_logic;
Example 1-39 Sub-module in config nested pkg.vhd
    library ieee;
    use ieee.std_logic_1164.all;
    use ieee.std_logic_unsigned.all;
    package components is
       component and_or is
          port (a : in std_logic;
                b : in std_logic;
                o : out std_logic);
       end component and_or;
       component sync_async is
          port (clk : in std_logic;
                rst : in std logic;
                 d1 : in std_logic;
```

d2: in std logic;

```
q : out std_logic);
        end component sync_async;
        component swap_exp is
          port (clk : in std_logic;
                 rst : in std logic;
                 din1 : in std_logic_vector(0 to 2);
                 din2 : in std_logic_vector(0 to 2);
                 dout : out std_logic_vector(0 to 2));
        end component swap_exp;
     end package components;
Example 1-40 Presto Log Report
analyze -f vhdl config_nested_and_or.vhd
Running PRESTO HDLC
Compiling Entity Declaration AND_OR
Compiling Architecture AND_OF_LOGIC of AND_OR
Compiling Architecture OR_OF_LOGIC of AND_OR
Warning: The entity 'and_or' has multiple architectures defined. The
last defined
architecture 'or_of_logic' will be used to build the design by default.
(VHD-6)
Presto compilation completed successfully.
analyze -f vhdl config_nested_pkg.vhd
Running PRESTO HDLC
Compiling Package Declaration COMPONENTS
Presto compilation completed successfully.
analyze -f vhdl config_nested_sync_async.vhd
Running PRESTO HDLC
Compiling Entity Declaration SYNC_ASYNC
Compiling Architecture SYNC_LOGIC of SYNC_ASYNC
Compiling Architecture ASYNC_LOGIC of SYNC_ASYNC
Warning: The entity 'sync_async' has multiple architectures defined. The
last defined
architecture 'async_logic' will be used to build the design by default.
Presto compilation completed successfully.
analyze -f vhdl config_nested_swap_exp.vhd
Running PRESTO HDLC
Compiling Entity Declaration SWAP_EXP
Compiling Architecture SWAP_SEQ of SWAP_EXP
Compiling Architecture COMB_SEQ of SWAP_EXP
Warning: The entity 'swap_exp' has multiple architectures defined. The
last defined
architecture 'comb_seq' will be used to build the design by default.
(WHD-6)
Presto compilation completed successfully.
analyze -f vhdl embed_nest_standalone_top.vhd
Running PRESTO HDLC
Compiling Entity Declaration EMBED_TOP
Compiling Architecture ARCH1 of EMBED_TOP
```

```
Compiling Configuration EMBED_TOP_CONFIG of EMBED_TOP
Presto compilation completed successfully.
elaborate embed_top_config
Loading db file '.../libraries/syn/gtech.db'
Loading db file '.../libraries/syn/standard.sldb'
 Loading link library 'gtech'
Running PRESTO HDLC
Component WORK.ARCH1/EMBED_TOP.ARCH1.SWAP_EXP1 has been configured to use
the
following
implementation:
     Work Library: WORK
     Design Name: SWAP_EXP
     Architecture Name: COMB_SEQ
Component WORK.ARCH1/EMBED_TOP.ARCH1.SWAP_EXP2 has been configured to use
t.he
following
implementation:
     Work Library: WORK
     Design Name: SWAP_EXP
     Architecture Name: SWAP_SEQ
Component WORK.ARCH1/EMBED_TOP.ARCH1.SWAP_EXP3 has been configured to use
following
implementation:
     Work Library: WORK
     Design Name: SWAP_EXP
     Architecture Name: COMB_SEQ
Presto compilation completed successfully.
Elaborated 1 design.
Current design is now 'embed_top'.
Information: Building the design 'SWAP_EXP' instantiated from design
'embed_top' with
the parameters "width1=3". (HDL-193)
Component WORK.COMB_SEQ/SWAP_EXP.COMB_SEQ.SEQ_GEN.REG has been configured
to use the
following implementation:
     Work Library: WORK
     Design Name: SYNC_ASYNC
     Architecture Name: SYNC_LOGIC
     Configuration Name :
WORK.EMBED_TOP_CONFIG.ARCH1.SWAP_EXP1.COMB_SEQ.SEQ_GEN.REG
Presto compilation completed successfully.
Information: Building the design 'SWAP_EXP' instantiated from design
'embed_top' with
the parameters "width1=3". (HDL-193)
Inferred memory devices in process
        in routine swap_exp_width13 line 28 in file
            '../vhdl_rtl/config_nested_swap_exp.vhd'.
______
                 Type | Width | Bus | MB | AR | AS | SR | SS | ST |
Register Name
______
    dout_reg | Flip-flop | 3 | Y | N | N | N | N | N |
______
Presto compilation completed successfully.
Warning: Design 'swap_exp_width13' was renamed to 'swap_exp_width13_1' to
```

```
avoid
a conflict with another design that has the same name but different
parameters.
(LINK-17)
Information: Building the design 'SWAP_EXP' instantiated from design
'embed_top' with
the parameters "width1=3". (HDL-193)
Component WORK.COMB_SEQ/SWAP_EXP.COMB_SEQ.SEQ_GEN.REG has been configured
to use the
following implementation:
    Work Library: WORK
    Design Name: SYNC_ASYNC
    Architecture Name: ASYNC LOGIC
    Configuration Name :
Presto compilation completed successfully.
Warning: Design 'swap_exp_width13' was renamed to 'swap_exp_width13_2' to
avoid a
conflict
with another design that has the same name but
different parameters. (LINK-17)
Information: Building the design 'SYNC_ASYNC' instantiated from design
'swap_exp_width13'
with the parameters "width2=4". (HDL-193)
Component WORK.SYNC_LOGIC/SYNC_ASYNC.SYNC_LOGIC.NEXT_LEVEL has been
configured to use
the following implementation:
    Work Library: WORK
    Design Name: AND_OR
    Architecture Name: AND_OF_LOGIC
    Configuration Name :
'report' output: in SYNC
Inferred memory devices in process
      in routine sync_async_width24 line 22 in file
          '../vhdl_rtl/config_nested_sync_async.vhd'.
______
Register Name | Type | Width | Bus | MB | AR | AS | SR | SS | ST |
______
   ______
Presto compilation completed successfully.
Information: Building the design 'SYNC_ASYNC' instantiated from design
'swap_exp_width13_2' with the parameters "width2=8". (HDL-193)
'report' output: in ASYNC
Inferred memory devices in process
       in routine sync_async_width28 line 38 in file
           '../vhdl_rtl/config_nested_sync_async.vhd'.
______
| Register Name | Type | Width | Bus | MB | AR | AS | SR | SS | ST |
______
    ______
Presto compilation completed successfully.
Information: Building the design 'AND_OR'. (HDL-193)
Presto compilation completed successfully.
```

#### Tool Behavior When Using Elaborate With the Entity Name

As noted in the previous sections, under certain conditions you need to elaborate using the configuration identifier. This section describes the problems that arise when you elaborate with the entity name.

Example 1-41 and Example 1-42 show incorrect ways to read the design described in Example 1-35 on page 1-39 through Example 1-39 on page 1-43. Recall that for this design you want the tool to select the "swap\_seq of swap\_exp" architecture. An explanation of the tool behavior follows the examples.

# Example 1-41 Incorrect Way to Read When Using the Stand-Alone Configuration: Elaborate with the Entity Name

```
analyze -f vhdl config_nested_sync_async.vhd
analyze -f vhdl config_nested_swap_exp.vhd
analyze -f vhdl embed_nested_standalone_top.vhd
elaborate embed_top
write -f ddc -h -o t.ddc
...
```

# Example 1-42 Incorrect Way to Read When Using Stand-Alone Configurations: read\_vhdl and link

```
"
read_vhdl config_nested_sync_async.vhd
read_vhdl config_nested_swap_exp.vhd
read_vhdl embed_nested_standalone_top.vhd
link
write -f ddc -h -o t.ddc
...
```

If you use the reading style in Example 1-41 or Example 1-42, Presto only checks the contents from the architecture\_body in the embed\_nest\_standalone\_top.vhd file. It will ignore the rest of the RTL code in that module. In this case, it will ignore the entire configuration portion of the top module even if you declare the configuration in the RTL.

The design architecture contains three components: swap\_exp1, swap\_exp2, and swap\_exp3.

For the first component, swap\_exp1, Presto ignores whatever you code in the configuration declarative section. Instead, the tool picks up the last defined architecture (comb\_seq of swap\_exp) by default and will not select the "swap\_seq of swap\_exp" architecture in the config\_nested\_swap\_exp.vhd module, which is declared in the architecture statements part in the top module. Next, since the architecture "comb\_seq of swap\_exp" has its own library declared, the tool will search for the last defined architecture in the module of config\_nested\_sync\_async.vhd, which is the architecture "async\_logic of sync\_async", and will use it by default instead of other architecture(s) in that module.

For the second component, swap\_exp2, the tool will be referred by the embedded configuration and will link to the architecture "swap\_seq of swap\_exp" in the config\_nested\_swap\_exp.vhd module, where it clearly states "use entity work.swap\_exp(swap\_seq)" as the embedded configuration in the architecture body.

For the last component, swap\_exp3, the tool chooses the last defined architecture "async\_logic of sync\_async" by default, for the same reasons as described earlier for swap\_exp1.

# **Design Libraries**

This section contains the following subsections:

- Predefined Design Libraries
- · Creating User-Defined Design Libraries
- User-Defined Design Library Example
- Using Design Units From Design Libraries
- Design Library Reports

#### **Predefined Design Libraries**

The following packages are analyzed for you:

- std logic 1164
- std logic arith
- · numeric\_std
- std\_logic\_misc
- Standard package
- Synopsys ATTRIBUTES package

These packages are contained in the logical libraries IEEE, WORK, DEFAULT, and SYNOPSYS, which are defined during installation. Their default physical locations are defined in the <code>.synopsys\_vss.setup</code> file, located in the Synopsys synthesis root installation subdirectory. These packages are described in Appendix B, "Predefined Libraries".

Packages defined in these libraries can be used by your VHDL source code and are found automatically. Example 1-43 shows how to use the predefined std\_logic\_1164 package from the IEEE library.

#### Example 1-43 Using Predefined Libraries

```
library IEEE;
use IEEE.std_logic_1164.all;
.
.
.
```

Unlike all the other predefined packages, the Standard package does not require a use clause to enable your design to use the functions with the package.

#### Note:

These predefined packages are compatible only with the software version they are released with; they are not compatible with other releases of the software. A version number is stored in the intermediate format file, and the file can be read in only by the version in which it was created.

# **Creating User-Defined Design Libraries**

When designs or packages are analyzed, the analyzed results are stored in the WORK library by default. If you want to store the results in a user-defined library, for example, MYLIB, with a physical location of MYLIB\_LOC, you can use one of two methods. In the first method, you use the define\_design\_lib variable; in the second, you use the .synopsys vss.setup file. These two methods are described in Table 1-6.

Table 1-6 Methods for Creating User-Defined Libraries

| Method              | Description                                                                                                                        |  |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------|--|
| define_design_lib   | Use the define_design_lib command to specify the library name and location; for example, define_design_lib MYLIB -path ./MYLIB_LOC |  |
|                     | Then analyze your design to MYLIB, for example, analyze -library MYLIB -format vhdl {{design}}                                     |  |
| .synopsys_vss.setup | Add the user-specified library name and mapping to your .synopsys_vss.setup file; for example,                                     |  |
|                     | MYLIB: ./ MYLIB_LOC                                                                                                                |  |
|                     | Then, analyze your design to MYLIB, for example,                                                                                   |  |
|                     | <pre>analyze -library MYLIB -format vhdl &lt;{design}&gt;</pre>                                                                    |  |

# **User-Defined Design Library Example**

The following steps show you how to store the analysis of two packages in a user-defined library named COMMON-TLS and use these packages in the ALU design.

- 1. Define a logical library called "COMMON-TLS" and map it to a physical location, using the define\_design\_lib command; for example,
  - 1. dc\_shell-t> define\_design\_lib COMMON-TLS -path ./COMMON
- 2. Store the analysis of the package files in the user-defined library COMMON-TLS (the packages reside in the files types.vhd and functions.vhd):
  - 3. dc\_shell> analyze -format vhdl -library COMMON-TLS
    {types.vhd functions.vhd}

The -library option indicates the library name where the analyzed file should be stored.

Declare the COMMON-TLS library in the ALU code:

```
library COMMON-TLS;
use COMMON-TLS.types.all;
use COMMON-TLS.functions.all;
```

Example 1-44 shows the complete flow using the analyze and elaborate commands (design ALU is defined in the files ALU\_entity.vhd and ALU\_arch.vhd.)

#### Example 1-44 Flow for User-Defined Library Using Analyze

```
dc_shell> define_design_lib WORK -path ./work
dc_shell> define_design_lib COMMON-TLS -path ./COMMON
dc_shell> analyze -format vhdl -library COMMON-TLS {types.vhd functions.vhd}
dc_shell> analyze -format vhdl {ALU_entity.vhd ALU_arch.vhd}
dc_shell> elaborate ALU_top
```

Example 1-45 shows the flow using the read command.

#### Example 1-45 Flow for User-Defined Library Using Read

```
dc_shell> define_design_lib WORK -path ./work
dc_shell> define_design_lib COMMON-TLS -path ./COMMON
dc_shell-t> read_vhdl -library COMMON-TLS {types.vhd functions.vhd}
dc_shell-t> read_vhdl {ALU_subblock.vhd ALU_top.vhd}
dc_shell-t> current_design ALU_top
dc shell-t> link
```

# **Using Design Units From Design Libraries**

Design libraries contain analyzed designs and packages used when you

- Elaborate designs—During elaboration, subdesigns are first linked by a search through
  designs in memory. Presto VHDL then searches the current design library for pre-existing
  analyzed files of the subdesigns. The .db files in the search path are also automatically
  linked during elaboration of a top-level design. See the elaborate man page for syntax
  details.
- Instantiate design units—Design units from design libraries can be instantiated into other designs. For example, you can instantiate the design adder by using

```
U1: entity adder (adder_arch)
   generic map (N => 16)
   port map (A,B,Z);
```

Call a package in a library with the use clause—The use clause allows an entity to use a
package from a library. Reference these packages in the declaration section of the entity
description.

# **Design Library Reports**

To get a complete list of design libraries, use the <code>report\_design\_lib</code> -libraries command. To view the contents of an individual library, such as the IEEE library, use <code>report\_design\_lib</code> IEEE. To find out a library's physical location, use the <code>get\_design\_lib\_path</code> command.

See the man pages for command details.

# **Package Support**

Presto VHDL supports the following packages:

- IEEE Package—std\_logic\_1164
- IEEE Package—std\_logic\_arith
- IEEE Package—numeric\_std (IEEE Standard 1076.3)
- IEEE Package—std\_logic\_misc
- · Standard Package
- Synopsys Package—ATTRIBUTES

See Appendix B for package details.

# **Array Naming Variables**

The three variables described in Table 1-7 affect how array elements are named. To list their current values, enter

dc\_shell-t> printvar bus\*style

Table 1-7 Array Naming Variables

| Variable                      | Description                                                                                                                                                                                                                                                                                                                      |  |  |
|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| bus_naming_style              | Describes how to name the bits in port, cell, and net arrays. When a multiple-bit array is read in, it is converted to a set of individual single-bit names. The value is a string containing the characters %s and %d, which are replaced by the array name and the bit (element) index, respectively. The default is "%s[%d]". |  |  |
|                               | Example:                                                                                                                                                                                                                                                                                                                         |  |  |
|                               | Array X_ARRAY is indexed from 0 to 7 and has bus_naming_style = "%s.%d"; Presto VHDL names the third element of X_ARRAY as X_ARRAY.2.                                                                                                                                                                                            |  |  |
|                               | Note: It is recommended that you do not change this default value if the netlist will be written out in Verilog format.                                                                                                                                                                                                          |  |  |
| bus_dimension_separator_style | Specifies the style to use in separating multidimensional array indexes. The default is "][".                                                                                                                                                                                                                                    |  |  |
| bus_minus_style               | Describes how to represent negative indexes in port, cell, and net names. The value is a string containing the characters %d (replaced by the absolute value of a negative index). The default is "-%d".                                                                                                                         |  |  |
|                               | Example:                                                                                                                                                                                                                                                                                                                         |  |  |
|                               | If bus_minus_style = "M%d", the index value of negative 3 is represented as "M3".                                                                                                                                                                                                                                                |  |  |

# **Licenses**

The reading and writing license requirements are listed in Table 1-8.

Table 1-8 License Requirements

| Reader              | Reading<br>License required? |         | Writing License required? |                |
|---------------------|------------------------------|---------|---------------------------|----------------|
|                     | RTL                          | Netlist | RTL                       | Netlist        |
| Presto VHDL         | Yes                          | Yes     | Not applicable            | Not applicable |
| VHDL netlist reader | Not applicable               | No      | No                        | No             |

# 2

## General Coding Considerations

This chapter discusses coding issues specific to Presto VHDL, in the following sections:

- Declarative Region in generate Statements
- Design Units
- Data Types and Data Objects
- Operands
- Modeling Considerations
- Simulation/Synthesis Mismatch Issues

## **Declarative Region in generate Statements**

Presto VHDL allows declarations within generate statements. Each iteration of the generate statement declares new copies of the objects in the declarative region. Consider Example 2-1, which describes four AND gates and four inverters. This code produces four independent signals named "S". Presto VHDL distinguishes these signals using a user-specified naming convention. This convention is determined by the hdlin\_generate\_naming\_style and hdlin\_generate\_separator\_style variables. See the man pages for information about these variables.

#### Example 2-1 Signal Declarations Within generate Statements

```
G: for I in 0 to 3 generate
  signal S: BIT;
begin
  S <= A(I) and B(I);
  Z(I) <= not S;
end generate;</pre>
```

Signals are not the only objects that can be declared within a generate statement. Consider Example 2-2.

#### Example 2-2 Function Declarations Within Generate Statements

```
G: for I in 0 to 3 generate
  function F (X: in BIT_VECTOR(0 to I)) return BIT is
  variable R: BIT := '1';
begin
  for J in X'RANGE loop
    R := R and x(j);
  end loop;
  return R;
  end function;
begin
  z(i) <= f (a(0 to i));
end generate;</pre>
```

Here, four versions of the function "f" are created, one for each iteration of the generate loop. Because the function is declared in the generate declarative region, it can only be called from the generate body.

## **Design Units**

Design unit requirements specific to Presto VHDL are discussed in the following subsections:

- Direct Instantiation of Components
- Default Component Port Assignments
- Component Name Restrictions
- Component Sources
- Component Port Consistency
- Instantiating Technology-Independent Components
- Component Architecture
- Package Names
- Procedures and Functions as Design Components

## **Direct Instantiation of Components**

Presto VHDL allows components to be directly instantiated in the design without a component declaration. This is a VHDL-93 feature that provides a more concise method of instantiating subdesigns. The following notation is used:

Presto VHDL always picks the last architecture analyzed for synthesis.

In the following examples, design1 (Example 2-3) is analyzed into a library called DESIGN1 LIB and design2 instantiates design1 (Example 2-4 on page 2-4).

#### Example 2-3 Design 1 RTL

Presto VHDL supports the direct instantiation of design1 without a component declaration as shown in Example 2-4. Notice that design2 now requires fewer lines of code.

#### Example 2-4 Design 2 Instantiates Design 1

## **Default Component Port Assignments**

Presto VHDL supports the use of default assignments for component port declarations as shown in Example 2-5. This simplifies coding by allowing ports with default assignments to be omitted during component instantiation.

#### Note:

Default assignments for entity port declarations will be parsed but ignored by Presto VHDL.

#### Example 2-5 Default Port Assignments

```
component AND3 is
  port (A: in bit;
      B: in bit;
      C: in bit:= '1'; -- default assignment to component port
      Z : out bit
    );
end component;
.
.
.
.
U1 : AND3
  port map (A => A1,
      B => B1,
      Z => Z1
    );
```

## **Component Name Restrictions**

You cannot name components with keywords, identifiers from any Synopsys or IEEE package, or the GTECH\_ prefix.

## **Component Sources**

A declared component can come from

- The same VHDL source file
- · A different VHDL source file
- Another format, such as EDIF, state table, or programmable logic arrays (PLAs)
- A component from a technology library
- A Verilog source file

A component that is not in one of the current VHDL source files must already have been compiled by Design Compiler and must reside either in memory or in a .db file in the search path. Presto VHDL searches for previously compiled components by name, in the following order:

- 1. In the current design in memory.
- 2. In the directories and files identified in the Design Compiler link path (link\_library variable). These files can include previously compiled designs or technology libraries (libraries of technology-specific components).
- 3. In the directories and files identified in the Design Compiler search path (search\_path variable).

## **Component Port Consistency**

Presto VHDL checks for consistent port mapping between all loaded designs. For RTL designs that are not VHDL or Verilog, the port names are taken from the original design description, as follows:

- For PLAs or state tables, the port names are the input and output names.
- For components in a technology library, the port names are the input and output pin names.
- For EDIF designs, the port names are the EDIF port names.

The bit-widths of each port must match.

- For VHDL components, Presto VHDL verifies matching.
- For components from other sources, Design Compiler checks matching when linking the component to the VHDL description.

## **Instantiating Technology-Independent Components**

You can directly instantiate GTECH components in your RTL. The GTECH library contains the following technology-independent logical components:

- AND, OR, and NOR gates (2, 3, 4, 5, and 8)
- 1-bit adders and half adders
- 2-of-3 majority
- Multiplexers
- · Flip-flops and latches
- Multiple-level logic gates, such as AND-NOT, AND-OR, and AND-OR-INVERT

#### Caution:

Instantiating GTECH components should be used with caution because it restricts the optimization of logic and might result in a degradation of design quality of results (QoR).

When you instantiate GTECH components, you can set the <code>map\_only</code> attribute to prevent Design Compiler from ungrouping the GTECH component and selecting a similar cell from the target library. When this attribute is applied, Design Compiler does not optimize the gates; instead, the gates are only mapped to the target technology. The <code>set\_map\_only</code> command in <code>Example 2-6</code> sets the <code>map\_only</code> attribute on each cell returned by the <code>find</code> command (all cells in the design RIPPLE\_CARRY that reference a GTECH\_ADD\_ABC cell). If you use your own library with attributes already set in that library, you do not have to set the <code>map\_only</code> attribute.

#### Example 2-6 GTECH Component Instantiation

```
library GTECH;
library ieee;
use IEEE.STD_LOGIC_1164.all;
use gtech.gtech_components.all;
entity RIPPLE_CARRY is
  generic(N: NATURAL);
  port(a, b : in std_logic_vector(n-1 downto 0);
      carry_in: in std_logic;
      sum : out std_logic_vector(n-1 downto 0);
      carry_out: out std_logic);
end RIPPLE_CARRY;
architecture TECH_INDEP of RIPPLE_CARRY is
  signal CARRY: std_logic_vector(N downto 0);
-- synopsys dc_tcl_script_begin
-- set_map_only [get_cells * -filter "ref_name==GTECH_ADD_ABC"]
-- synopsys dc_tcl_script_end
begin
  CARRY(0) <= CARRY_IN;</pre>
  GEN: for I in 0 to N-1 generate
    U1: GTECH_ADD_ABC port map(
             Α
                          => A(I),
             В
                          => B(I),
             С
                          => CARRY(I),
             S
                          => SUM(I),
             COUT
                          => CARRY(I+1)
            );
  end generate GEN;
  CARRY_OUT <= CARRY(N);</pre>
end TECH INDEP;
```

To link this design in Design Compiler, you must have the GTECH.db library in your link\_library variable.

## **Component Architecture**

Presto VHDL uses the following two rules to select which entity and architecture to associate with a component instantiation:

1. Each component declaration must have an entity—a VHDL entity, a design entity from another source or format, or a library component—with the same name. This entity is used for each component instantiation associated with the component declaration.

 If a VHDL entity has more than one architecture, Presto VHDL uses the last architecture analyzed. You can override this selection by using configurations. See "Configuration Support" on page 1-20.

## **Package Names**

Synopsys supports different packages with the same name if they exist in different libraries.

## **Procedures and Functions as Design Components**

Procedures and functions are represented by gates and cannot exist as entities (components) unless you use the directive <code>map\_to\_entity</code>, which causes Presto VHDL to implement a function or a procedure as a component instantiation. Procedures and functions that use <code>map\_to\_entity</code> are represented as components in designs where they are called.

When you add a map\_to\_entity directive to a subprogram definition, Presto VHDL assumes the existence of an entity with the identified name and the same interface.

Presto VHDL and Design Compiler do not check this assumption until they link the parent design. The matching entity must have the same input and output port names. If the subprogram is a function, you must also provide a <code>return\_port\_name</code> directive where the matching entity has an output port of the same name.

These two directives are called component implication directives:

```
-- synopsys map_to_entity entity_name
-- synopsys return_port_name port_name
```

Insert these directives after the function or procedure definition, as in the following example:

```
function MUX_FUNC(A,B: in TWO_BIT; C: in BIT)
    return TWO_BIT is
-- synopsys map_to_entity MUX_ENTITY
-- synopsys return_port_name Z
```

When Presto VHDL encounters the map\_to\_entity directive, it parses but ignores the contents of the subprogram definition.

The matching entity (*entity\_name*) does not need to be written in VHDL. It can be in any format Design Compiler supports.

#### Note:

Be aware that the behavioral description of the subprogram is not checked against the functionality of the entity overloading it. Pre-synthesis and post-synthesis simulation results might not match if differences in functionality exist between the VHDL subprogram and the overloaded entity.

Example 2-7 shows a function that uses component implication directives. Figure 2-1 on page 2-10 illustrates the corresponding design.

## Example 2-7 Using Component Implication Directives on a Function

```
package MY_PACK is
         subtype TWO_BIT is BIT_VECTOR(1 to 2);
         function MUX_FUNC(A,B: in TWO_BIT; C: in BIT) return
               TWO_BIT;
end;
package body MY_PACK is
         function MUX_FUNC(A,B: in TWO_BIT; C: in BIT) return
               TWO_BIT is
         -- synopsys map_to_entity MUX_ENTITY
         -- synopsys return_port_name Z
         -- contents of this function are ignored but should match the
         -- functionality of the entity MUX_ENTITY, so pre- and post
         -- simulation will match
         begin
               if(C = '1') then
                     return(A);
               else
                     return(B);
               end if;
         end;
end;
use WORK.MY_PACK.ALL;
entity TEST is
         port(A: in TWO_BIT; C: in BIT; TEST_OUT: out TWO_BIT);
end:
architecture ARCH of TEST is
begin
         cal_func: process (a, c)
         begin
               TEST_OUT <= MUX_FUNC(not A, A, C);</pre>
                                -- Component implication call
         end process;
end:
use WORK.MY_PACK.ALL;
-- the following entity 'overloads' the function MUX_FUNC above
entity MUX_ENTITY is
         port(A, B: in TWO_BIT; C: in BIT; Z: out TWO_BIT);
```

Figure 2-1 Schematic Design With Component Implication Directives



Example 2-8 shows the same design as Example 2-7, but without the creation of an entity for the function. The component implication directives have been removed. Figure 2-2 on page 2-11 illustrates the corresponding design.

#### Example 2-8 Using Gates to Implement a Function

```
package MY_PACK is
         subtype TWO_BIT is BIT_VECTOR(1 to 2);
         function MUX_FUNC(A,B: in TWO_BIT; C: in BIT)
               return TWO_BIT;
end;
package body MY_PACK is
         function MUX_FUNC(A,B: in TWO_BIT; C: in BIT)
                return TWO_BIT is
         begin
                if(C = '1') then
                     return(A);
                else
                      return(B);
                end if;
         end;
end;
```

Figure 2-2 Schematic Design Without Component Implication Directives



## **Data Types and Data Objects**

Data type and data object requirements specific to Presto VHDL are discussed in the following subsections:

- Globally Static Expressions in Port Maps
- Aliases
- Deferred Constants
- Aggregates in Constant Record Declarations
- Enumerated Types in the for and for-generate Constructs
- Groups
- Integer Data Types
- Overloading an Enumeration Literal

- Enumeration Encoding
- Constant Floating-Point Support
- math\_real Package Support

## **Globally Static Expressions in Port Maps**

Presto VHDL supports globally static expressions in port maps as shown in Example 2-9.

### Example 2-9 Presto VHDL Supports Globally Static Expressions in Port Maps

```
component C is
  port (A, B: in BIT; Z: out BIT);
end component;
. . .
signal X, Y: BIT
. . .
U1: C port map (X, '1', Y);
```

### **Aliases**

Presto VHDL supports all alias types except labels, loop parameters, and generate parameters—these cannot be aliased per the VHDL language reference manual. Example 2-10 shows alias code that is supported in Presto VHDL.

#### Example 2-10 Presto VHDL Supported Alias

```
entity e is
  port (a, c: in bit;
     z: out bit);
end;

architecture a of e is
  alias b is c;
begin
  z <= a and b;
end;</pre>
```

Presto VHDL alias support includes the following:

- Aliases without an explicit subtype indication as shown in Example 2-11 on page 2-13
- · Aliases with an explicit subtype indication
- Aliases to non-objects (that is, types) as shown in Example 2-12 on page 2-13
- Aliases to subprograms as shown in Example 2-13 on page 2-13

#### Example 2-11 Alias Without an Explicit Subtype Indication

```
signal S: BIT_VECTOR (0 to 7);
...
alias A is S;
```

In this case, A will have the same type as S.

#### Example 2-12 Alias to a Type

```
alias SLV is STD_LOGIC_VECTOR;
```

Example 2-13 shows an alias to a subprogram. This is a convenient way to refer to a specific subprogram in a package.

#### Example 2-13 Aliases to Subprograms

Subprogram aliases can also contain a signature. This makes it possible to distinguish among the various interpretations of an overloaded subprogram name as shown in Example 2-14.

#### Example 2-14 Subprogram Alias Containing a Signature

#### **Deferred Constants**

Constants defined in packages are useful for declaring a set of global design parameters that can be shared by multiple design entities. Example 2-15 shows how a constant declared in a global package DEFS is used to define the active edge for the clocks in the design. The value of "1" means that the flip-flops will be clocked on the rising edge of the clock.

#### Example 2-15 shows a deferred constant declaration in a package.

#### Example 2-15 Deferred Constants

```
-- defs_pkg.vhd
-- =========
library ieee;
use ieee.std_logic_1164.all;
package defs is
constant CLOCK_ACTIVE_EDGE: std_logic := '1';
end:
design1.vhd
========
library ieee, mylib;
use ieee.std logic 1164.all;
use mylib.defs.all;
  process (clk) is
  begin
     if (clk'event and clk = CLOCK ACTIVE EDGE) then
       O \leq D;
     end if;
  end process;
```

One of the limitations of normal constant declarations in packages is that if the constant value in the package is changed, then all the designs making use of that package must be reanalyzed in order to use the new constant value. In the above example, this means that if you want to change to a negative clock edge, you need to modify the CLOCK\_ACTIVE\_EDGE from "1" to "0" in defs\_pkg.vhd and reanalyze all the files that reference this package.

With deferred constants, the constant is declared in the package without initializing its value. The initialization of the constant is deferred to the package body declaration. Now if the constant value is changed in the package body, only the package body needs to be reanalyzed, followed by a re-elaboration of the top-level design. Example 2-16 shows how a deferred constant declaration can be used to define the active edge for the clocks in the design.

#### Example 2-16 Deferred Constant Declaration

```
defs_pkg.vhd
=========
package DEFS is
constant CLOCK_ACTIVE_EDGE: std_logic;
end DEFS;

defs_pkg_body.vhd
============
package body DEFS is
constant CLOCK_ACTIVE_EDGE: std_logic := '1';
end;
```

Now if you want to change from a positive-edge-triggered to a negative-edge-triggered behavior, you only need to modify and reanalyze the package body, in defs\_pkg\_body.vhd, and, re-elaborate the top-level design to implement the change. This allows for a more flexible and manageable design flow.

## **Aggregates in Constant Record Declarations**

Presto VHDL Compiler supports the use of aggregates in constant record declarations as shown in Example 2-17.

#### Example 2-17 Aggregates in Constant Record Declarations

## **Enumerated Types in the for and for-generate Constructs**

Presto VHDL supports the use of enumerated types as indexes in the for and for-generate constructs. Example 2-18 uses an enumerated type as an index in a for loop.

#### Example 2-18 Enumerated Types As Index in for Construct

```
package Defs is
type color is (RED, GREEN, BLUE);
subtype col_val is bit_vector (7 downto 0);
type pixel is array (color range RED to BLUE) of col_val;
function pix_fn (A1, A2: col_val) return col_val;
end Defs;
package body Defs is
  function pix_fn (A1, A2: col_val) return col_val is
   return (A1 xor A2);
  end pix_fn;
end Defs;
use work.Defs.all;
entity pix is
 port (A, B: in pixel;
       Z: out pixel
       );
end pix;
architecture rtl of pix is
begin
  process (A, B)
  begin
    for I in RED to BLUE loop
                               -- enumerated type used here
      Z(I) \le pix_fn(A(I),B(I));
    end loop;
  end process;
end rtl;
```

## **Groups**

Presto VHDL supports VHDL-93 group declarations as shown in Example 2-19. This feature allows you to create groups of named entities. One useful application of this feature is that you can apply attributes to the group as a whole instead of referencing individual signals.

#### Example 2-19 Group Declarations

```
package Defs is
group sig_grp is (signal<>);
end Defs;
library Synopsys;
use Synopsys.attributes.all;
use work.Defs.all;
entity top is
port (A, B: in bit;
      Z: out bit
     );
end top;
architecture RTL of top is
group sig3_grp is (signal, signal, signal);
group inputs: sig_grp (A, B);
group all_ports: sig3_grp (A, B, Z);
-- input delay of 1.5 will be applied to A & B signals
attribute ARRIVAL of inputs: group is 1.5;
begin
  Z \ll A \text{ or } B;
end RTL;
```

## **Integer Data Types**

Multidigit numbers in VHDL can include underscores (\_) to make them easier to read.

Presto VHDL encodes an integer value as a bit vector whose length is the minimum necessary to hold the defined range and encodes integer ranges that include negative numbers as 2's-complement bit vectors.

## **Overloading an Enumeration Literal**

You can overload an enumeration literal by including it in the definition of two or more enumeration types. When you use such an overloaded enumeration literal, Presto VHDL is usually able to determine the literal's type. However, under certain circumstances, determination might be impossible. In such cases, you must qualify the literal by explicitly stating its type. Example 2-20 shows how you can qualify an overloaded enumeration literal.

#### Example 2-20 Enumeration Literal Overloading

```
type COLOR is (RED, GREEN, YELLOW, BLUE, VIOLET);
type PRIMARY_COLOR is (RED, YELLOW, BLUE);
signal A : COLOR;
...
A <= COLOR'(RED);</pre>
```

## **Enumeration Encoding**

Enumeration literals are synthesized into the binary equivalent of their positional value. By default, the first enumeration literal is assigned the value 0, the next enumeration literal is assigned the value 1, and so forth.

Presto VHDL automatically encodes enumeration values into bit vectors that are based on each value's position. The length of the encoding bit vector is the minimum number of bits required to encode the number of enumerated literals. For example, an enumeration type with five values would have a 3-bit encoding vector.

Example 2-21 shows the default encoding of an enumeration type with five values.

#### Example 2-21 Automatic Enumeration Encoding

```
type COLOR is (RED, GREEN, YELLOW, BLUE, VIOLET);
```

The enumeration values are encoded as follows:

```
RED = "000"

GREEN = "001"

YELLOW = "010"

BLUE = "011"

VIOLET = "100"
```

The colors can be compared according to their encoded values; the results of a comparison are

RED < GREEN < YELLOW < BLUE < VIOLET.

You can override the automatic enumeration encodings and specify your own enumeration encodings with the <code>ENUM\_ENCODING</code> attribute. This interpretation is specific to Presto VHDL, and overriding might result in a simulation/synthesis mismatch. See "ENUM\_ENCODING Attribute" on page 6-9.

## **Constant Floating-Point Support**

This section describes constant floating-point support, in the following subsections:

- Syntax and Declarations
- Operators and Expressions
- Guidelines

## **Syntax and Declarations**

Floating-point syntax:

```
constant identifier list : real subtype [:= expression] ;
```

You can declare constant floating-point objects in

- Entities (except for generic maps)
- Architectures
- Processes
- Blocks
- Functions (as an argument, a return value, or a declarative part)
- Procedures (as an argument or a declarative part)

The following types can consist of constant floating-point objects:

- Scalar
- Array
- Record

Example 2-22 shows various constant floating-point declarations.

### Example 2-22

```
-- real array(subscript op)
        type REAL_ARRAY_T is array (3 downto 0) of real;
        constant my_const3: REAL_ARRAY_T := (4.4, 3.3, 2.2, 1.1);
-- real array with range (vector op)
        type REAL_ARRAY_T2 is array (integer range<>) of real;
        constant my_const4: REAL_ARRAY_T2(3 downto 0) := (4.4, 3.3, 2.2,
1.1);
        constant my_const5: REAL_ARRAY_T2(1 downto 0) := aa(2 downto 1);
-- real record(field op)
        type RECORD T is record
            rec1: integer;
            rec2: string(3 downto 1);
            rec3: real;
        end record;
        constant my_rec: RECORD_T := (5, "mmm", 3.14);
-- constant floating point can also be argument and return value
-- of functions and procedures.
        function func1(aa : real;
                           a, b : in bit) return bit;
        function func2(aa, bb : real) return real;
        procedure proc1(aa : real;
                            a, b : in bit;
                                : out bit);
```

## **Operators and Expressions**

The following operators are supported for constant floating-point type:

- Adding, signing, multiplying, and absolute value operators
- \*\* (power) operator ( <real data> \*\* <integer data> )
- Relational operators (>, <, =, /=, >=, <=)
- Subscript and vector operators (array)
- Field operator (record)

Example 2-23 shows various expressions that contain constant floating-types. In Example 2-23, my\_const1 and my\_const2 are constant floating-point types; my\_rec is a constant record type; rec1 is an element of my\_rec.

#### Example 2-23

```
my_const1 + 3.14
my_const1/(-my_const2)
abs(-my_const1)
my_const1 ** 5
my_const1 >= my_const2
```

```
my_const1(3), my_const1(2 downto 0)
my_rec.rec1
```

Expressions can contain floating-point numbers and constants, but these expressions are only allowed at the following locations:

- Constant floating-point initialization
- Comparison (relational operation)

The value of an expression that contains a constant floating point must be resolvable at elaboration time.

In Example 2-24, the floating-point constant, my\_const1 (3.14), is smaller than 5.6, so the condition in the if statement is true. This causes Presto VHDL to elaborate the first clause of the if statement and ignore the second clause. Presto VHDL assigns bb to false, because my\_const1 (equaling 3.14) is known at elaboration time.

#### Example 2-24

```
constant my_const1 : real :=3.14;
    ...
    if (my_const1 <= 5.6) then
        state <= a;
    else
        state <= b;
    endif;
    ...
    bb <= (my_const1/=3.14); -- bb is BOOLEAN type
    ...</pre>
```

#### **Guidelines**

- Floating-point objects are supported on Linux platforms, 32-bit sparc/hp platforms, and 64-bit sparc/hp platforms.
- Floating-point signal and variable objects are not supported, and can not be synthesized; only constant floating point objects are supported.
- Floating-point objects in the generic map of an entity are not supported.
- The floating-point range is -1.0e38 to 1.0e38 inclusive, the same as the float type in C.
- The floating-point object initialization expression must be present and its value must be resolvable at the time of elaboration, or an error is reported.

## math\_real Package Support

This section describes Presto VHDL support for the IEEE standard VHDL math\_real package, which defines arithmetic functions using REAL type arguments.

This section contains the following:

- Unsupported Constructs and Operators
- Using the math\_real Package
- Arithmetic Functions
- Usage Examples

## **Unsupported Constructs and Operators**

Presto VHDL does not support the following components:

- Is\_X() function is a simulation rather than synthesis construct; it is ignored in synthesis
- REAL signals
- · REAL types with ranges

## Using the math\_real Package

The math\_real package is typically installed in the Synopsys root directory. Access it with the following statement in your VHDL code:

```
Library IEEE;
Use IEEE.math_real.all;
```

NOTE: Operations on REAL type data are only supported for constant evaluation.

#### **Arithmetic Functions**

The math\_real package provides arithmetic functions for use with the REAL data type. These functions can be used in synthesis for constant calculations. Example 2-25 shows the declaration of these functions.

#### Example 2-25

```
function "**" (X : in INTEGER; Y : in REAL) return REAL;
function "**" (X : in REAL; Y : in REAL) return REAL;
function "MOD" (X, Y : in REAL) return REAL;
function ARCCOS (X : in REAL) return REAL;
function ARCCOSH (X : in REAL) return REAL;
function ARCSIN (X : in REAL) return REAL;
function ARCSINH (X : in REAL) return REAL;
```

```
function ARCTAN (Y: in REAL) return REAL;
function ARCTAN (Y: in REAL; X: in REAL) return REAL;
function ARCTANH (X : in REAL) return REAL;
function CBRT (X : in REAL) return REAL;
function CEIL (X : in REAL) return REAL;
function COS (X : in REAL) return REAL;
function COSH (X : in REAL) return REAL;
function EXP (X : in REAL) return REAL;
function FLOOR (X : in REAL) return REAL;
function LOG (X : in REAL) return REAL;
function LOG (X : in REAL; BASE : in REAL) return REAL;
function LOG10 (X : in REAL) return REAL;
function LOG2 (X: in REAL) return REAL;
function REALMAX (X, Y: in REAL) return REAL;
function REALMIN (X, Y : in REAL) return REAL;
function ROUND (X : in REAL) return REAL;
function SIGN (X : in REAL) return REAL;
function SIN (X: in REAL) return REAL;
function SINH (X : in REAL) return REAL;
function SQRT (X : in REAL) return REAL;
function TAN (X : in REAL) return REAL;
function TANH (X : in REAL) return REAL;
function TRUNC (X : in REAL) return REAL;
procedure UNIFORM(variable SEED1, SEED2 : inout POSITIVE; variable X :
out REAL);
```

## **Usage Examples**

See Example 2-26 and Example 2-27 on page 2-24.

#### Example 2-26 Constant Evaluation of Parameters

```
constant i1 : integer := integer(param4);
```

#### Example 2-27 User Defined Functions

```
function realtodb(val : real ) return real is
begin
return 20.0*(log10(val));
end function;

CONSTANT Ar : real := 1.375;
CONSTANT Ar_db : real := realtodb(Ar);
```

## **Operands**

Operand requirements specific to Presto VHDL are discussed in the following subsections:

- Operand Bit-Width
- Array Slice Names
- Computable and Noncomputable Operands
- Indexed Name Targets

## **Operand Bit-Width**

Presto VHDL uses the bit-width of the largest operand to determine the bit-width needed to implement an operator in a circuit. For example, an INTEGER operand is 32 bits wide by default. An addition of two INTEGER operands causes Presto VHDL to build a 32-bit adder.

To use hardware resources efficiently, always indicate the bit-width of numeric operands. For example, use a subrange of INTEGER when declaring types, variables, or signals.

```
type ENOUGH: INTEGER range 0 to 255;
variable WIDE: INTEGER range -1024 to 1023;
signal NARROW: INTEGER range 0 to 7;
```

## **Array Slice Names**

Slice names identify a sequence of consecutive elements of an array variable or signal. The syntax is

identifier (expression direction expression)

#### identifier

The identifier is the name of a signal or variable of an array type. Each *expression* must return a value within the array's index range and must be computable (see "Computable and Noncomputable Operands" on page 2-25).

#### direction

The *direction* must be either to or downto. The direction of a slice must be the same as the direction of an identifier's array type. If the left and right expressions are equal, they define a single element.

The value returned to an operator is a subarray containing the specified array elements.

## Computable and Noncomputable Operands

A computable operand is one whose value can be determined by Presto VHDL at compile time, that is, the operand value is constant and doesn't depend on any inputs. Noncomputable operand values depend on inputs that are known only at runtime. Because the operand value varies according to inputs, Presto VHDL needs to build additional logic to determine what the value is at runtime.

Following are examples of computable operands:

- Literal values
- for...loop parameters, when the loop's range is computable
- Variables assigned a computable expression
- Aggregates that contain only computable expressions
- Function calls whose return value is computable
- Expressions with computable operands
- Qualified expressions when the expression is computable
- Type conversions when the expression is computable
- The value of the and or nand operators when one of the operands is a computable '0'

• The value of the or operator or the nor operator when one of the operands is a computable '1'

Additionally, a variable is given a computable value if it is an OUT or INOUT parameter of a procedure that assigns it a computable value.

Typically, the following are noncomputable operands:

- Signals
- Ports
- Variables assigned different computable values that depend on a noncomputable condition
- Variables assigned noncomputable values

Example 2-28 shows some definitions and declarations, followed by several computable and noncomputable expressions.

#### Example 2-28 Computable and Noncomputable Expressions

```
signal S: BIT;
function MUX(A, B, C: BIT) return BIT is
begin
  if (C = '1') then
    return(A);
  else
    return(B);
  end if;
end;
procedure COMP(A: BIT; B: out BIT) is
  B := not A;
end;
process(S)
  variable V0, V1, V2: BIT;
  variable V_INT: INTEGER;
  subtype MY_ARRAY is BIT_VECTOR(0 to 3);
  variable V_ARRAY: MY_ARRAY;
begin
  V0 := '1'; -- Computable (value is '1')
V1 := V0; -- Computable (value is '1')
V2 := not V1; -- Computable (value is '0')
  for I in 0 to 3 loop
    V_INT := I; -- Computable (value depends on iteration)
  end loop;
  V_ARRAY := MY_ARRAY'(V1, V2, '0', '0');
                             -- Computable ("1000")
  V1 := MUX(V0, V1, V2); -- Computable (value is '1')
  COMP(V1, V2);
                             -- Computable (value is '0')
  V1 := V2;
  V1 := V2; -- Computable (value is 0, V0 := S and '0'; -- Computable (value is '0') V1 := MUX(S, '1', '0'); -- Computable (value is '1')
  V1 := MUX('1', '1', S); -- Computable (value is '1')
  if (S = '1') then
    V2 := '0';
                           -- Computable (value is '0')
  else
                     -- Computable (value is '1')
    V2 := '1';
  end if;
                Noncomputable; V2 depends on SNoncomputable; S is a nonfixed signalNoncomputable; V1 is no longer computable
  V0 := V2;
  V1 := S;
  V2 := V1;
end process;
```

## **Indexed Name Targets**

The syntax for an assignment to an indexed name (identifier) target is

```
identifier(index_expression) := expression; -- Variable assignment
identifier(index_expression) <= expression; -- Signal assignment</pre>
```

The identifier is the name of an array type signal or variable.

The index\_expression must evaluate to an index value for the identifier array's index type and bounds. It does not have to be computable, but more hardware is synthesized if it is not. See "Computable and Noncomputable Operands" on page 2-25.

The assigned expression must have the array's element type.

## **Modeling Considerations**

Modeling requirements specific to Presto VHDL are discussed in the following subsections:

- Concatenation
- Unconstrained Type Ports
- · Input Ports Associated With the Keyword open
- Multiple Events in a Single Process
- Keeping Signal Names
- Controlling Structure
- Resolution Functions
- Asynchronous Designs
- Using Don't Care Values
- Finite State Machines
- Multibit Inference

## Concatenation

Both the 87 and 93 VHDL language reference manual (LRM) definitions of the concatenation operator are supported by the HDL Compiler (Presto VHDL) tool. The default support is for the 93 LRM definition. To enable the 87 LRM definition, set hdlin vhdl93 concat to false. To help understand the difference between the two

definitions, consider Example 2-29. In this example, constant k3 and k4 are defined using concatenation with constants k1 and k2. The value of k3 and k4 will differ according to what VHDL language standard you use: VHDL-87 or VHDL-93.

If you use VHDL-93, the value of K3'left to K3'right is the same as K4'left to K4'right. To determine this value, the tool counts from 0 to 3 and the value does not depend on the K1 and K2 start positions.

If you use VHDL-87, the value of K3'left to K3'right, which is from 0 to 3, is different from K4'left to K4'right, which is from 1 down to -2, because concatenation in VHDL-87 defines the position count from the start position of the left operand K1 position (1) and the procedure (downto) instead of starting from the 0 position, as is the case in the VHDL-93 language standard.

#### Example 2-29 Understanding Concatenation in VHDL-93 and VHDL-87

Example 2-30 shows the values of constants k2, k3, k4, and k5 when interpreted using VHDL-87 and VHDL-93 definitions.

#### Example 2-30

```
-- 87 concat: K2'left = 1 and k2'right = 5

constant k3: t1 := k1(5 to 7) & k1(1 to 2);

-- 93 concat: k3'left = 0 and k3'right = 4

-- 87 concat: k3'left = 5 and k3'right = 9

constant k5: t2 := k4(3 downto 1) & k1(3 to 4);

-- 93 concat: k5'left = 0 and k5'right = 4

-- 87 concat: k5'left = 3 and k5'right = -1
```

## **Unconstrained Type Ports**

Presto VHDL supports the usage of unconstrained type ports when the type of the ports can be deduced. In these cases, you must use the analyze and elaborate commands to read your design. The read command does not support type conversion on formal ports.

## Input Ports Associated With the Keyword open

If you associate an input port with the reserved keyword open, you must initialize it with a default expression, or the analyze command will report an error. Presto VHDL connects the open port with the default expression after elaboration.

## Multiple Events in a Single Process

Presto VHDL supports multiple events in a single process as shown in Example 2-31.

#### Example 2-31

```
process
begin
  wait until CLOCK'event and CLOCK = '1';
  if (CONDITION) then
    X <= A;
  else
    wait until CLOCK'event and CLOCK = '1';
  end if;
end process;</pre>
```

## **Keeping Signal Names**

When a signal is in a path to an output port, Presto VHDL usually keeps the signal's name if the signal isn't removed during optimizations, such as removing redundant code. You can give Presto VHDL guideline information for keeping a signal name by using the hdlin\_keep\_signal\_name variable and the keep\_signal\_name directive. The default is all\_driving. Table 2-1 describes the variable options.

Table 2-1 hdlin\_keep\_signal\_name Variable Options

| Option                                                                                                                                                                                                                                                                                                                                | Description                                                                                                                                                                                                    |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| user  This option works with the keep_signal_name directive. Presto VHDL atter preserve a signal if the signal isn't removed by optimizations and that signal with the keep_signal_name directive. Both dangling and driving nets are called Although not guaranteed, Presto VHDL typically keeps the specified signal configuration. |                                                                                                                                                                                                                |
| all_driving<br>(default)                                                                                                                                                                                                                                                                                                              | Presto VHDL attempts to preserve a signal if the signal isn't removed by optimizations and the signal is in an output path. Only driving nets are considered. This option does not guarantee a signal is kept. |

#### Note:

When a signal has no driver, the tool assumes logic 0 (ground) for the driver

To prevent signals from being removed during optimizations, use the keep\_signal\_name directive, as shown in Example 2-32 and Example 2-33. Note that this directive works together with the hdlin\_keep\_signal\_name variable. For the examples, this variable is set to user. Review the variable options and set this variable to your specific requirements before reading your design.

#### Example 2-32 Keep Signal tmp

```
entity bus_name is
   port (
      in1 : in bit_vector (1 downto 0);
      in2 : in bit_vector (1 downto 0);
      z : out bit_vector (1 downto 0));
end bus_name;

architecture imp of bus_name is
-- synopsys keep_signal_name "tmp"
   signal tmp : bit_vector (1 downto 0);
begin
   process(in1, in2)
begin
   tmp <= in1 and in2;
   z <= in1;
end process;</pre>
```

```
end imp;
```

### Example 2-33 Keep Signal tmp1 and tmp2

## **Controlling Structure**

You can use parentheses to force the synthesis of parallel hardware. For example, (A + B) + (C + D) builds an adder for A+B, an adder for C+D, and an adder to add the result. Design Compiler preserves the subexpressions dictated by the parentheses, but this restriction on Design Compiler optimizations might lead to less-than-optimum area and timing results.

Parentheses can also be helpful in coding for late-arriving signals. For example, if you are adding three signals—A, B, and C—and A is late arriving, then A+(B+C) can be useful in handling the late-arriving signal A. Note that Design Compiler will also try to create a structure to allow the late-arriving signal to meet timing. Any restriction on Design Compiler optimizations might lead to less-than-optimum area and timing results.

## **Resolution Functions**

The resolution function and the coding style determine the choice of wired logic. Synthesis neither checks for nor resolves possible data collisions on a synthesized three-state bus. It is the responsibility of the designer to ensure that the three-state enablers for a common bused line are not active at the same time.

Synopsys has modified the resolution function in std\_logic\_1164, by adding to it the resolution\_method\_three\_state directive which enables you create multiply-driven signals of type std\_logic and std\_logic\_vector that will synthesize into three-state gates when the appropriate coding style is used. If you want wired-and or wired-or gates synthesized, you must write your own package, as shown in Example 2-34.

Presto VHDL does not support arbitrary resolution functions. Only wired AND, wired OR, and three-state functions are allowed. Presto VHDL requires that you mark all resolution functions with a directive indicating the kind of resolution being performed.

Presto VHDL considers the directive only when creating hardware. The body of the resolution function is parsed but ignored.

Do not connect signals that use different resolution functions. Presto VHDL supports only one resolution function per network.

The three resolution function directives are

- synopsys resolution method wired and
- synopsys resolution method wired or
- synopsys resolution method three state

Pre-synthesis and post-synthesis simulation results might not match if the body of the resolution function the simulator uses does not match the directive the synthesizer uses.

Example 2-34 shows how to create and use a resolved signal and how to use compiler directives for resolution functions. The signal's base type is the predefined type BIT. Figure 2-3 shows the design.

#### Example 2-34 Resolved Signal and Its Resolution Function

```
package RES_PACK is
  function RES_FUNC(DATA: in BIT_VECTOR) return BIT;
  subtype RESOLVED_BIT is RES_FUNC BIT;
end;

package body RES_PACK is
  function RES_FUNC(DATA: in BIT_VECTOR) return BIT is
  -- synopsys resolution_method wired_and
  begin
  -- The code in this function is ignored by Presto VHDL
```

```
-- but parsed for correct VHDL syntax
    for I in DATA'range loop
      if DATA(I) = '0' then
         return '0';
      end if;
    end loop;
   return '1';
  end;
end;
use work.RES_PACK.all;
entity WAND_VHDL is
 port(X, Y: in BIT; Z: out RESOLVED_BIT);
end WAND_VHDL;
architecture WAND VHDL of WAND VHDL is
  Z \ll X;
 Z \ll Y;
end WAND_VHDL;
```

Figure 2-3 Design Using Resolved Signal



## **Asynchronous Designs**

If you use asynchronous design techniques—that is, nonclocked designs—synthesis and simulation results might not agree. Because Design Compiler does not issue warning messages for asynchronous designs, you are responsible for verifying the correctness of your circuit. See the *Synopsys Timing Constraints and Optimization User Guide* for additional information.

## **Using Don't Care Values**

Presto VHDL always evaluates comparisons to don't care values to false. This behavior is different from simulation behavior. To prevent a synthesis/simulation mismatch, always use the IEEE 1076.3-1997 STD\_MATCH function when using don't care values in comparisons. See "Don't Care Values in Comparisons" on page 2-44.

## **Finite State Machines**

Presto VHDL automatically infers finite state machines (FSMs). For FSM optimization details, see the *Design Compiler Reference Manual: Optimization and Timing Analysis*.

This section includes the following subsections:

- Variables and Commands Specific to FSM Inference
- FSM Coding Requirements
- FSM Example and Inference Report
- State Vector Attribute

See Appendix A for additional FSM examples.

## **Variables and Commands Specific to FSM Inference**

The variables and commands listed in Table 2-2 are specific to FSM inference.

Table 2-2 Variables and Commands Specific to FSM Inference

| Variables/Commands    | Description                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hdlin_reporting_level | Default is basic. Variable enables and disables FSM inference reports. When set to comprehensive, FSM inference reports are generated when Presto VHDL reads the code. By default, FSM inference reports are not generated. For more information, including valid values, see "Elaboration Reports" on page 1-7.                                                                |
| fsm_auto_inferring    | Default is false. Option determines whether or not Design Compiler automatically extracts the FSM during compile. This option controls Design Compiler extraction. In order to automatically infer and extract an FSM, fsm_auto_inferring must be true. See the Design Compiler Reference Manual: Optimization and Timing Analysis and the man page for additional information. |

For more information about these variables and commands, see the man pages.

## **FSM Coding Requirements**

Follow the coding guidelines in Table 2-3 to enable Presto VHDL to infer an FSM.

Table 2-3 RTL Requirements for Automatic Detection of FSMs

| Item                         | Description                                                                                                                                                                                                                                                                                                                               |  |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Registers                    | To infer a register as an FSM state register, the register                                                                                                                                                                                                                                                                                |  |
|                              | Must never be assigned a value other than the defined state values.                                                                                                                                                                                                                                                                       |  |
|                              | Must always be inferred as a flip-flop (not a latch).                                                                                                                                                                                                                                                                                     |  |
|                              | Must never be a design port, function port, or task port. This would make the encoding visible to the outside.                                                                                                                                                                                                                            |  |
|                              | Inside expressions, FSM state registers can be used only as an operand of "==" or "/=" comparisons or as the expression in a case statement that is an implicit comparison to the label expressions, such as "case (cur_state)". FSM state registers are not allowed to occur in other expressions—this would make the encoding explicit. |  |
| Function                     | There can be only one FSM design per entity. State variables cannot drive a port. State variables cannot be indexed.                                                                                                                                                                                                                      |  |
| Ports                        | All ports of the initial design must be either input ports or output ports. Inout ports are not supported.                                                                                                                                                                                                                                |  |
| Combinational feedback loops | Combinational feedback loops are not supported, although combinational logic that does not depend on the state vector is accurately represented.                                                                                                                                                                                          |  |
| Clocks                       | FSM designs can include only a single clock and an optional synchronous or asynchronous reset signal.                                                                                                                                                                                                                                     |  |

### **FSM Example and Inference Report**

When you set the hdlin\_reporting\_level variable to comprehensive, Presto VHDL creates an FSM inference report, as shown in Example 2-36 on page 2-39. The report describes the FSM state encoding that Presto VHDL created from the RTL. Example 2-35 on page 2-38 shows the FSM RTL code, and Figure 2-4 shows an FSM state diagram based on that code. For more information about the hdlin\_reporting\_level variable, see "Elaboration Reports" on page 1-7.

Figure 2-4 FSM State Diagram



#### Example 2-35 FSM RTL Code

```
library IEEE;
use IEEE.std_logic_1164.all;
entity FSM is
 port(CLK : in std_logic;
       X : in std_logic;
       Y : out std_logic);
end FSM;
architecture STATE_MACHINE_VIEW of FSM is
  -- Declare an enum type for the state
  type STATE_TYPE is (S0, S1, S2, S3);
  signal STATE : STATE_TYPE;
  signal NEXT_STATE : STATE_TYPE;
  begin
  -- This process sets the next state on the clock edge.
  SET_STATE: process(CLK, NEXT_STATE) begin
     if (CLK'event and CLK = '1') then
       STATE <= NEXT_STATE;</pre>
     end if;
  end process SET_STATE;
  -- This process determines the next state and output
  -- values based on the current state and input values.
  SET_NEXT_STATE: process(STATE, X) begin
    -- SET defaults for NEXT_STATE and all outputs.
    Y <= '0';
    NEXT_STATE <= S0;</pre>
    case STATE is
      when S0 =>
          Y <= '0';
          NEXT STATE <= S1;
      when S1 =>
        if (X = '0') then
          Y <= '0';
          NEXT_STATE <= S1;</pre>
        else
          Y <= '1';
          NEXT_STATE <= S2;</pre>
        end if;
      when S2 =>
          Y <= '0';
          NEXT_STATE <= S3;</pre>
      when S3 =>
          Y <= '0';
          NEXT_STATE <= S0;</pre>
    end case;
  end process SET_NEXT_STATE;
end STATE_MACHINE_VIEW;
```

#### Example 2-36 Finite State Machine Inference Report

#### **State Vector Attribute**

When inferring FSMs, always check your FSM inference report to verify that Presto VHDL correctly inferred the FSM. If you want to change a state encoding, you can do so by using the STATE\_VECTOR attribute in the architecture to specify state vectors for your design in the BTL.

When writing a state machine in VHDL, you can use a STATE\_VECTOR attribute to provide information to Design Compiler. Use a STATE\_VECTOR attribute in the architecture; the attribute value is the name of the state signal. Use only one STATE\_VECTOR attribute for an architecture, as shown in Example 2-37.

#### Example 2-37 Using STATE\_VECTOR Attribute in Architecture

See the *Design Compiler Reference Manual: Optimization and Timing Analysis* for more information on specifying and encoding state machines.

#### **Multibit Inference**

Presto VHDL can infer multibit components. These components reduce area and power consumption in a design, but their primary benefits are the creation of a more uniform structure for layout during place and route.

This section contains the following:

- Multibit Inference Overview
- Controlling Multibit Inference
- infer\_multibit Attribute Examples

#### **Multibit Inference Overview**

Multibit inference allows you to map registers, multiplexers, and three-state cells to regularly structured logic or multibit library cells. Multibit library cells (the macrocells, such as a 16-bit banked flip-flop, in the library) have these advantages:

- Smaller area and delay, due to shared transistors (as in select or set/reset logic) and optimized transistor-level layout
  - In the use of 1-bit components, the select or set/reset logic is repeated in each 1-bit component.
- Reduced clock skew in sequential gates, because the clock paths are balanced internally in the hard macro implementing the multibit component.
- Lower power consumption by the clock in sequential banked components, due to reduced capacitance driven by the clock net
- · Better performance due to the optimized multibit layout
- Improved regular layout of the datapath

Multibit components might not be efficient in the following instances:

- As state machine registers
- In small bused logic that would benefit from single-bit design

## **Controlling Multibit Inference**

Presto VHDL infers as multibit components only register, multiplexer, and three-state cells that have identical structures for each bit.

To direct Presto VHDL to infer multibit components, do one of the following:

• Embed the attribute, infer\_multibit, in the HDL source.

The attribute gives you control over individual case statements. Set the infer\_multibit attribute to true on signals and variables to infer them as multibit components. See Example 2-38 on page 2-42.

• Use the dc\_shell variable, hdlin\_infer\_multibit.

This variable controls multibit inference for all bused registers, multiplexers, and three-state cells you input in the same dc\_shell session. The options are

- default\_none: Infers multibit components for signals that have the infer\_multibit attribute set to true in the VHDL RTL. This is the default.
- default\_all: Infers multibit components for all bused registers, multiplexers, and three-state cells. To disable multibit mapping for certain signals, set infer\_multibit to false in the VHDL code on those signals.
- never: Does not infer multibit components, regardless of the attributes or directives in the HDL source.

To adjust the design after layout, use the following commands:

- create multibit: Infers multibit components in a mapped design.
- remove multibit: Removes multibit components from a mapped design.

For more information on how Design Compiler handles multibit components in a mapped design, see the *Design Compiler Reference Manual: Optimization and Timing Analysis*.

## infer\_multibit Attribute Examples

In Example 2-38, the infer\_multibit attribute—highlighted in bold—is set on signal q. Example 2-39 shows the inference report. In this report, the column MB indicates that the component is inferred as a multibit component.

#### Example 2-38 Inferring a Multibit 4-Bit Latch With Asynchronous Reset

```
library IEEE, Synopsys;
use IEEE.std_logic_1164.all;
use Synopsys.attributes.all;
entity d_latch_async_reset_4 is
port (enable, reset : in std_logic;
           data : in std_logic_vector(3 downto 0);
           q : out std_logic_vector(3 downto 0));
end d_latch_async_reset_4;
architecture rtl of d_latch_async_reset_4 is
attribute async_set_reset of reset : signal is "true";
attribute infer_multibit of q : signal is "true";
begin
     proc1 : process (enable, data, reset)
           begin
           if (reset = '1') then
           q \ll "0000";
           elsif (enable = '1') then
           q <= data;
           end if;
     end process proc1;
end rtl;
```

#### Example 2-39 Inference Report for a 4-Bit Latch With Asynchronous Reset

| Register Name | ====================================== | =======<br>  Width | ====================================== | =======<br>  AR   AS | ====================================== |
|---------------|----------------------------------------|--------------------|----------------------------------------|----------------------|----------------------------------------|
| q_reg         | Latch                                  | 4                  | Y   Y                                  | Y   N                | -   -   -                              |

Example 2-40 shows the same VHDL code but illustrates how to prevent multibit inference of signal q. Bold highlights the infer\_multibit attribute. The inference report is shown in Example 2-41. In this report, the column MB indicates that the component is not inferred as a multibit component.

#### Example 2-40 Latch With Asynchronous Reset Without Multibit Inference

```
library IEEE, Synopsys;
use IEEE.std_logic_1164.all;
use Synopsys.attributes.all;
entity d_latch_async_reset_4_nomb is
port (enable, reset : in std_logic;
           data : in std_logic_vector(3 downto 0);
           q : out std_logic_vector(3 downto 0));
end d latch async reset 4 nomb;
architecture rtl of d_latch_async_reset_4_nomb is
attribute async_set_reset of reset : signal is "true";
attribute infer_multibit of q : signal is "false";
begin
     proc1 : process (enable, data, reset)
           begin
           if (reset = '1') then
           q \ll "0000";
           elsif (enable = '1') then
           q <= data;
           end if;
     end process proc1;
end rtl;
```

#### Example 2-41 Inference Report for a Latch Without Multibit Inference

```
| Register Name | Type | Width | Bus | MB | AR | AS | SR | SS | ST |
| q_reg | Latch | 4 | Y | N | Y | N | - | - | - |
```

## **Simulation/Synthesis Mismatch Issues**

This following sections describe simulation/synthesis mismatch issues:

- Type Mismatches
- · Set and Reset Signals
- Z Values in Expressions
- Don't Care Values in Comparisons
- Ordering of Enumerated Types Using the ENUM\_ENCODING attribute
- Sensitivity Lists
- Delay Specifications

## **Type Mismatches**

The numeric\_std package and the std\_logic\_arith package have overlapping operations. Use of these two packages simultaneously during analysis could cause type mismatches.

## **Set and Reset Signals**

A simulation/synthesis mismatch can occur if the set/reset signal is masked by an X during initialization in simulation. Use of the <code>sync\_set\_reset</code> directive reduces mismatches. For examples, see "D Flip-Flop With Synchronous Set" on page 4-22 and "D Flip-Flop With Synchronous Reset" on page 4-23.

## **Z Values in Expressions**

The use of the z value in an expression always evaluates to false and can cause a simulation/synthesis mismatch. For details, see "Understanding the Limitations of Three-State Inference" on page 5-9.

## **Don't Care Values in Comparisons**

To prevent simulation/synthesis mismatch, do not use don't care values in comparisons unless you use the IEEE 1076.3-1997 STD\_MATCH function.

Don't care types are treated differently in simulation than they are in synthesis. To a simulator, a don't care value is a distinct value, different from a 1 or a 0. In synthesis, however, a don't care value becomes a 0 or a 1. When a don't care value is used in a comparison, Presto VHDL always evaluates the comparison to false. Because of this difference in treatment, there is the potential for a simulation/synthesis mismatch whenever a comparison is made with a don't care value.

#### For example,

```
if X = '-' then
```

#### is synthesized as

if FALSE then

The following case statement causes a synthesis/simulation mismatch because the simulator evaluates 1- to match 11 and 10 but the synthesis tool evaluates 1- to false; the same hold true for the 0- evaluation.

To fix this mismatch problem, always use the STD\_MATCH function; for example, rewrite the code above by using if statements, as follows:

```
if (STD_MATCH (A, "1,-"))
....
elseif (STD_MATCH (A, "0,-"))
....
else
```

Presto VHDL issues a warning similar to the following when it synthesizes such comparisons:

```
Warning: A partial don't-care value was read in routine test line 24 in file 'test.vhd' This may cause simulation to disagree with synthesis. (HDL-171)
```

## Ordering of Enumerated Types Using the ENUM ENCODING attribute

If you set the encoding of your enumerated types by using the ENUM\_ENCODING attribute, the ordering operators compare your encoded value ordering, not the declaration ordering. Because this interpretation is specific to Presto VHDL, it might cause a mismatch with the VHDL simulator, which uses the declaration's order of enumerated types. See "Enumeration Encoding" on page 2-18 and "ENUM\_ENCODING Attribute" on page 6-9.

## **Sensitivity Lists**

Presto VHDL generates a warning if all the signals read by the process are not listed in the sensitivity list. The circuit Presto VHDL synthesizes is sensitive to all signals the process reads. To guarantee the same results from a VHDL simulator, follow these guidelines when developing the sensitivity list:

- For sequential logic, include the clock signal and all asynchronous control signals in the sensitivity list.
- For combinational logic, all inputs must be in the sensitivity list.

Presto VHDL checks sensitivity lists for completeness and issues a warning message for any signal that is read inside a process but is not in the sensitivity list. An error message is issued if a clock signal is read as data in a process.

#### Note:

The IEEE VHDL standard does not allow a sensitivity list if the process has a wait statement. If your code has this condition, Presto VHDL will issue a warning and ignores the code.

## **Delay Specifications**

Delays are ignored for synthesis; their use may cause a synthesis/simulation mismatch.

# 3

## Modeling Combinational Logic

This chapter describes coding guidelines specific to Presto VHDL that are useful in combinational logic synthesis.

This chapter contains the following sections:

- Synthetic Operators
- Logic and Arithmetic Operator Implementation
- Propagating Constants
- Bit-Truncation Coding for DC Ultra Datapath Extraction
- Multiplexing Logic
- Unintended Latches and Feedback Paths in Combinational Logic

## **Synthetic Operators**

Synopsys provides a collection of IP, referred to as the DesignWare Basic IP Library, as part of the HDL Compiler products. Basic IP provide basic implementations of common arithmetic functions that can be referenced by HDL operators in your VHDL or Verilog source code.

The DesignWare paradigm is built on a hierarchy of abstractions. HDL operators (either built-in operators like + and \*, or HDL functions and procedures) are associated with synthetic operators, which are bound in turn to synthetic modules. Each synthetic module can have multiple architectural realizations, called implementations. When you use the HDL addition operator "+" in a design description, Presto VHDL infers the need for an adder resource, and puts an abstract representation of the addition operation into your circuit netlist. The same holds true when you instantiate a DesignWare component. For example, an instantiation of DW01\_add will be mapped to the synthetic operator associated with it. See Figure 3-1.

A synthetic library contains definitions for synthetic operators, synthetic modules, and bindings. It also contains declarations that associate synthetic modules with their implementations.

For more information about DesignWare synthetic operators, modules, and libraries, see the Synopsys DesignWare documentation.

Figure 3-1 DesignWare Hierarchy



## **Logic and Arithmetic Operator Implementation**

When Presto VHDL elaborates a design, it maps HDL operators to synthetic (DesignWare) operators that appear in the generic netlist. When Design Compiler optimizes the design, it maps these operators to DesignWare synthetic modules and chooses the best implementation, based on constraints, option settings, and wire-load models.

A Design Compiler license includes a DesignWare-Basic license that enables the DesignWare synthetic modules listed in Table 3-1. These modules support common logic and arithmetic HDL operators. By default, adders and subtracters must be more than 4 bits wide to be mapped to these modules. If they are smaller, the operators are mapped to combinational logic.

Table 3-1 Operators Supported by a DesignWare-Basic License

| HDL operator                        | Linked to DesignWare synthetic module |
|-------------------------------------|---------------------------------------|
| Comparison (> or <)                 | DW01_cmp2                             |
| Absolute value (abs)                | DW01_absval                           |
| Addition (+)                        | DW01_add                              |
| Subtraction (-)                     | DW01_sub                              |
| Addition or Subtraction (+ or -)    | DW01_addsub                           |
| Incrementer (+)                     | DW01_inc                              |
| Decrementer (-)                     | DW01_dec                              |
| Incrementer or decrementer (+ or -) | DW01_incdec                           |
| Multiplier (*)                      | DW02_mult                             |

Synopsys creates numerous DesignWare synthetic modules in addition to the basic modules. The DesignWare Building Block IP (formally called Foundation Library) is a collection of reusable intellectual property blocks that are integrated into the Synopsys synthesis environment. This library contains high-performance implementations of Basic Library IP plus many IP that implement more advanced arithmetic and sequential logic functions. For more information about DesignWare synthetic modules, see the DesignWare documentation.

## **Propagating Constants**

Constant propagation is the compile-time evaluation of expressions containing constants. Presto VHDL uses constant propagation to reduce the amount of hardware required to implement operators. For example, a "+" operator with a constant 1 as an input causes an incrementer, rather than a general adder, to be built. If both adder arguments are constants, no hardware is constructed, because the expression's value is calculated by Presto VHDL and inserted directly in the circuit.

Other operators that benefit from constant propagation include comparators and shifters. Shifting a vector by a constant amount requires no logic to implement; it requires only a reshuffling (rewiring) of bits.

## **Bit-Truncation Coding for DC Ultra Datapath Extraction**

Datapath design is commonly used in applications that contain extensive data manipulation, such as 3-D, multimedia, and digital signal processing (DSP). Datapath extraction transforms arithmetic operators, such as addition, subtraction, and multiplication, into datapath blocks to be implemented by a datapath generator.

The DC Ultra tool enables datapath extraction after timing-driven resource sharing and explores various datapath and resource-sharing options during compile.

As of release T-2002.05, DC Ultra datapath optimization supports datapath extraction of expressions containing truncated operands unless both of the following two conditions exist:

- The operands have upper bits truncated.
- The width of the resulting expression is greater than the width of the truncated operand.

Both conditions must be true to prevent extraction. For lower-bit truncations, the datapath is extracted in all cases.

Bit truncation can be either explicit or implicit. Table 3-2 describes both types of truncation.

Table 3-2 Explicit and Implicit Bit Truncation

| Truncation type         | Description                                                                                |
|-------------------------|--------------------------------------------------------------------------------------------|
| Explicit bit truncation | An explicit upper-bit truncation is one in which you specify the bit range for truncation. |
|                         | The following code indicates explicit upper-bit truncation of operand A:                   |
|                         | signal A = std_logic_vector (i downto 0);                                                  |
|                         | $z \le A$ (j downto 0); where j < i                                                        |

Table 3-2 Explicit and Implicit Bit Truncation (Continued)

| Truncation type         | Description                                                                                                                                                                                                                                                                                             |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Implicit bit truncation | An implicit upper-bit truncation is one that occurs through assignment. Unlike explicit upper-bit truncation, here you do not explicitly define the range for truncation.                                                                                                                               |
|                         | The following code indicates implicit upper-bit truncation of operand Y:                                                                                                                                                                                                                                |
|                         | signal A,B = std_logic_vector (7 downto 0);                                                                                                                                                                                                                                                             |
|                         | signal C,Y = std_logic_vector (8 downto 0);                                                                                                                                                                                                                                                             |
|                         | Y = A + B + C;                                                                                                                                                                                                                                                                                          |
|                         | Because A and B are each 8 bits wide, the return value of A+B will be 8 bits wide. However, because Y, which is 9 bits wide, is assigned to be the 9-bit wide addition (A+B)+C, the most significant bit (MSB) of the addition (A+B) is implicitly truncated. In this example, the MSB is the carryout. |

To see how bit truncation affects datapath extraction, consider the code in Example 3-1.

In this example, d has the upper bit truncated, but e is only 8-bits so this code is extracted.

#### Example 3-1 Design test1: Truncated Operand Is Extracted

In Example 3-2, d is truncated to 8-bits and in an expression assigned to e which is 9-bits. This code is not extracted.

#### Example 3-2 Design test2: Truncated Operand Is Not Extracted

```
library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.std_logic_unsigned.all;
entity test2 is
  port (a,b,c : in std_logic_vector(7 downto 0);
        e : out std_logic_vector(8 downto 0)); -- e is 9-bits wide
end test2;
architecture rtl of test2 is
  signal d : std_logic_vector(15 downto 0); -- d is 16-bit wide
begin
```

```
d \le a * b;

e \le 0'&c + d(7 downto 0); -- explicit upper bit truncation end rtl;
```

In Example 3-3, the expression assigned to e contains implicit upper-bit truncation and the width of e is greater than the width of the implicitly truncated operand, so the code is not extracted.

#### Example 3-3 Design test3: Truncated Operand Is Not Extracted

In Example 3-4, there is lower-bit truncation but no upper-bit truncation so this code is extracted.

#### Example 3-4 Design test4: Truncated Operand is Extracted

```
library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.std_logic_unsigned.all;
entity test4 is
  port (a,b : in std_logic_vector(7 downto 0);
        e : out std_logic_vector(7 downto 0));
end test4;
architecture rtl of test4 is
  signal d : std_logic_vector(15 downto 0); -- d is 16-bit wide
begin
  d <= a * b; -- no implicit upper bit truncation of d
  e <= d(15 downto 8); -- explicit lower bit truncation of d
end rtl;</pre>
```

## **Multiplexing Logic**

Multiplexers are commonly modeled with if and case statements. To implement this logic, Presto VHDL uses SELECT\_OP cells, which Design Compiler maps to combinational logic or multiplexers in the technology library. If you want Design Compiler to preferentially map multiplexing logic to multiplexers—or multiplexer trees—in your technology library, you must infer MUX OP cells.

The following sections describe multiplexer inference:

- SELECT OP Inference
- MUX\_OP Inference
- Variables That Control MUX\_OP Inference
- MUX\_OP Inference Examples
- MUX\_OP Inference Limitations

### **SELECT OP Inference**

By default, Presto VHDL uses SELECT\_OP components to implement conditional operations implied by if and case statements. An example SELECT\_OP cell implementation for an 8-bit data signal is shown in Figure 3-2.



Figure 3-2 SELECT\_OP Implementation for an 8-bit Data Signal

Note that for an 8-bit data signal, 8 selection bits are needed - this is called a one-hot implementation.

SELECT\_OPs behave like one-hot multiplexers; the control lines are mutually exclusive, and each control input allows the data on the corresponding data input to pass to the output. To determine which data signal is chosen, Presto VHDL generates selection logic, as shown in Figure 3-3.

data signals output select signals

Figure 3-3 Presto VHDL Output—SELECT\_OP and Selection Logic

Depending on the design constraints, Design Compiler will implement the SELECT\_OP with either combinational logic or multiplexer cells from the technology library.

### **MUX\_OP Inference**

If you want Design Compiler to preferentially map multiplexing logic in your RTL to multiplexers—or multiplexer trees—in your technology library, you need to infer MUX\_OP cells. These cells are hierarchical generic cells optimized to use the minimum number of select signals. They are typically faster than the SELECT\_OP cell, which uses a one-hot implementation. Although MUX\_OP cells improve design speed, they also might increase area. During optimization, Design Compiler preferentially maps MUX\_OP cells to multiplexers—or multiplexer trees—from the technology library, unless the area costs are prohibitive, in which case combinational logic is used. See the *Design Compiler Reference Manual: Optimization and Timing Analysis* for information about how Design Compiler maps MUX\_OP cells to multiplexers in the target technology library.

Figure 3-4 shows a MUX\_OP cell for an 8-bit data signal. Notice that the MUX\_OP cell only needs three control lines to select an output; compare this with the SELECT\_OP which needed eight control lines.

DATA8

DATA7

DATA6

DATA5

DATA4

DATA3

DATA2

DATA1

S0

select signals

Figure 3-4 MUX\_OP Generic Cell for an 8-bit Data Signal

Note that for an 8-bit word, only 3 selection bits are needed.

The MUX\_OP cell contains internal selection logic to determine which data signal is chosen; Presto VHDL does not need to generate any selection logic, as shown in Figure 3-5.

Figure 3-5 Presto VHDL Output—MUX\_OP Generic Cell for 8-Bit Data



Use the following methods to infer MUX\_OP cells:

- To generate MUX\_OP cells for a specific case or if statement, use the infer\_mux attribute or the --synopsys infer\_mux directive in the VHDL description.
  - Attach the infer\_mux attribute to a case statement, by using the following syntax: case var is --synopsys infer\_mux

Attach the infer\_mux directive, as follows:

```
case SEL3 is -- synopsys infer_mux
when "00" => DOUT3 <= DIN3(0);
when "01" => DOUT3 <= DIN3(1);
when "10" => DOUT3 <= DIN3(2);
when "11" => DOUT3 <= DIN3(3);</pre>
```

- To generate MUX\_OP cells for all case statements in a block, set the infer\_mux attribute on the block.
  - Attach the infer\_mux attribute to a process, by using the following syntax:

```
attribute infer_mux of process_label : label is "true";
```

• To generate MUX\_OP cells for all case and if statements, use the hdlin\_infer\_mux variable.

### **Variables That Control MUX\_OP Inference**

The variables that control MUX\_OP cell inference are listed in Table 3-3.

Table 3-3 MUX OP Inference Variables

| Variable        | Description                                                                                                                                                                                                                                                                                                           |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| hdlin_infer_mux | This variable controls MUX_OP inference for all designs you input in the same Design Compiler session.                                                                                                                                                                                                                |  |
|                 | Options:                                                                                                                                                                                                                                                                                                              |  |
|                 | <ul> <li>default—Infers MUX_OPs for case and if statements in<br/>processes that have the infer_mux directive or attribute<br/>attached.</li> </ul>                                                                                                                                                                   |  |
|                 | <ul> <li>none—Does not infer MUX_OPs, regardless of the directives<br/>set in the VHDL description. Presto VHDL generates a warning<br/>if hdlin_infer_mux = none and infer_mux are used in the<br/>RTL.</li> </ul>                                                                                                   |  |
|                 | <ul> <li>all—Infers MUX_OPs for every case and if statement in your<br/>design for which one can be used. This can negatively affect<br/>the quality of results, because it might be more efficient to<br/>implement the MUX_OPs as random logic instead of using a<br/>specialized multiplexer structure.</li> </ul> |  |

Table 3-3 MUX\_OP Inference Variables (Continued)

| Variable                     | Description                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hdlin_mux_size_limit         | This variable sets the maximum size of a MUX_OP that Presto VHDL can infer. The default value is 32. If you set this variable to a value greater than 32, Presto VHDL may take an unusually long elaboration time.                                                                                                                                                                                        |
|                              | If the number of branches in a case statement exceeds the maximum size specified by this variable, Presto VHDL generates the following message:                                                                                                                                                                                                                                                           |
|                              | Warning: A mux was not inferred because case statement %s has a very large branching factor. (HDL-383)                                                                                                                                                                                                                                                                                                    |
| hdlin_mux_size_min           | Sets the minimum number of data inputs for a MUX_OP inference. Default value is 2.                                                                                                                                                                                                                                                                                                                        |
| hdlin_mux_oversize_<br>ratio | Defined as the ratio of the number of MUX_OP inputs to the unique number of data inputs. When this ratio is exceeded, a MUX_OP will not be inferred and the circuit will be generated with SELECT_OPs. Default value is 100.                                                                                                                                                                              |
| hdlin_mux_size_only          | To ensure that MUX_OP cells are mapped to MUX technology cells, you must apply a <code>size_only</code> attribute to the cells to prevent logic decomposition in later optimization steps. You can set the <code>size_only</code> attribute on each MUX_OP manually or allow the tool to set it automatically. The automatic behavior can be controlled by the <code>hdlin_mux_size_only</code> variable. |
|                              | Options:                                                                                                                                                                                                                                                                                                                                                                                                  |
|                              | O-Specifies that no cells receive the size_only attribute.      One office that MUX_OR calls that are generated with the                                                                                                                                                                                                                                                                                  |
|                              | <ul> <li>1-Specifies that MUX_OP cells that are generated with the<br/>RTL infer_mux pragma and that are on set/reset signals<br/>receive the size_only attribute. This is the default setting.</li> </ul>                                                                                                                                                                                                |
|                              | <ul> <li>2-Specifies that all MUX_OP cells that are generated with the<br/>RTL infer_mux pragma receive the size_only attribute.</li> </ul>                                                                                                                                                                                                                                                               |
|                              | <ul> <li>3-Specifies that all MUX_OP cells on set/reset signals receive the size_only attribute: for example, MUX_OP cells that are generated by setting the hdlin_infer_mux variable to all.</li> </ul>                                                                                                                                                                                                  |
|                              | <ul> <li>4-Specifies that all MUX_OP cells receive the size_only<br/>attribute: for example, MUX_OP cells that are generated by the<br/>hdlin_infer_mux variable set to all.</li> </ul>                                                                                                                                                                                                                   |
|                              | By default, the hdlin_mux_size_only variable is set to 1, meaning that MUX_OP cells that are generated with the RTL infer_mux pragma and that are on set/reset signals receive the size_only attribute.                                                                                                                                                                                                   |

## **MUX\_OP Inference Examples**

In Example 3-5, two MUX\_OPs and one SELECT\_OP are inferred, as follows:

- In the process proc1, a MUX\_OP is inferred for the case statement, because the infer\_mux attribute is placed on proc1.
- In the process proc2, there are two case statements.
  - For the first case statement, a SELECT OP is inferred. This is the default inference.
  - However, the second case statement in proc2 has the infer\_mux pragma set on it which causes Presto VHDL to infer the MUX\_OP cell.

Example 3-6 shows the inference report for the MUX\_OPs. Figure 3-6 shows a representation of the Presto VHDL implementation.

#### Example 3-5 Two MUX OPs and One SELECT OP Inferred

```
library ieee, synopsys;
use ieee.std_logic_1164.all;
use synopsys.attributes.all;
entity test is
  port (DIN1 : in std_logic_vector (7 downto 0);
        DIN2 : in std logic vector (7 downto 0);
        DIN3 : in std logic vector (3 downto 0);
        SEL1 : in std_logic_vector (2 downto 0);
        SEL2 : in std_logic_vector (2 downto 0);
        SEL3 : in std_logic_vector (1 downto 0);
        DOUT1 : out std_logic;
        DOUT2 : out std_logic;
        DOUT3 : out std logic
      );
end test;
architecture rtl of test is
attribute infer mux of proc1 : label is "TRUE";
begin
  -- A MUX_OP for DOUT1 will be inferred from the
  -- infer mux attribute set on proc1
  proc1 : process (SEL1, DIN1)
  begin
     case SEL1 is
       when "000" => DOUT1 <= DIN1(0);
       when "001" \Rightarrow DOUT1 \iff DIN1(1);
       when "010" \Rightarrow DOUT1 \iff DIN1(2);
       when "011" \Rightarrow DOUT1 \iff DIN1(3);
```

```
when "100" => DOUT1 <= DIN1(4);
         when "101" \Rightarrow DOUT1 \iff DIN1(5);
         when "110" => DOUT1 <= DIN1(6);
         when "111" => DOUT1 <= DIN1(7);
         when others => DOUT1 <= DIN1(0);
     end case;
  end process;
  proc2 : process (SEL2, SEL3, DIN2, DIN3)
  begin
  -- A SELECT OP will be generated for DOUT2
  -- in the absence of an infer_mux attribute
      case SEL2 is
         when "000" => DOUT2 <= DIN2(0);
        when "000" => DOUT2 <= DIN2(0);

when "001" => DOUT2 <= DIN2(1);

when "010" => DOUT2 <= DIN2(2);

when "011" => DOUT2 <= DIN2(3);

when "100" => DOUT2 <= DIN2(4);
         when "101" \Rightarrow DOUT2 \iff DIN2(5);
         when "110" \Rightarrow DOUT2 \iff DIN2(6);
         when "111" \Rightarrow DOUT2 \iff DIN2(7);
         when others => DOUT2 <= DIN2(0);
     end case;
  -- A MUX_OP will be inferred for DOUT3 from the
  -- infer_mux pragma placed on this case statement
     case SEL3 is -- synopsys infer_mux
       when "00" => DOUT3 <= DIN3(0);
when "01" => DOUT3 <= DIN3(1);
when "10" => DOUT3 <= DIN3(2);
when "11" => DOUT3 <= DIN3(3);</pre>
       when others => DOUT3 <= DIN3(0);
     end case;
  end process;
end rtl;
```

Example 3-6 shows the MUX\_OP inference report for the code in Example 3-5. The tool displays inference reports by default. If you do not want these reports displayed, you can turn them off using the hdlin\_reporting\_level variable. For more information about the hdlin\_reporting\_level variable, see "Elaboration Reports" on page 1-7.

Example 3-6 Inference Report for the Process in Example 3-5

Statistics for MUX\_OPs

| block name/line | ====================================== | ====================================== |   | ======<br>  MB  <br> |
|-----------------|----------------------------------------|----------------------------------------|---|----------------------|
| proc1/24        | 8                                      | 1                                      | 3 | N                    |
| proc2/55        | 4                                      | 1                                      | 2 | N                    |

Figure 3-6 Presto VHDL Implementation



## **MUX\_OP Inference Limitations**

Presto VHDL does not infer MUX\_OP cells for

- case statements in while loops
- case statements embedded in if-then-else statements, unless the case statement appears in an if (CLK'event...) or in an elsif (CLK'event...) branch in the VHDL description

MUX\_OP cells are inferred for incompletely specified case statements, such as case statements that

- · Contain an if statement or an others clause that covers more than one value
- Have a missing case statement branch or a missing assignment in a case statement branch

- Contain don't care values (X or "-")
- Are in an elsif (CLK'event...) branch

but the logic might be nonoptimum, because other optimizations are disabled when you infer MUX\_OP cells under these conditions. For example, Presto VHDL optimizes default branches by default. If the <code>infer\_mux</code> attribute is on the case statement, this optimization is not done.

When inferring a MUX\_OP for an incompletely specified case statement, Presto VHDL generates the following ELAB-304 warning:

```
Warning: Case statement has an infer_mux attribute and a default branch or incomplete mapping. This can cause nonoptimal logic if a mux is inferred. (ELAB-304)
```

## Unintended Latches and Feedback Paths in Combinational Logic

Presto VHDL infers a latch when a signal or variable in a combinational process (one without a wait or if signal'event statement) is not fully specified in the VHDL description. A variable or signal is fully specified when it is assigned under all possible conditions. A variable or signal is not fully specified when a condition exists under which the variable is not assigned.

Example 3-7 shows several variables. A, B, and C are fully specified; X is not.

#### Example 3-7 Variable X Is Not Fully Specified

```
process (COND1)
  variable A, B, C, X : BIT;
begin
  A := '0' -- A is fully specified
  C := '0'
              -- C is fully specified
  if (COND1) then
    B := '1'; -- B is assigned when COND1 is TRUE
    C := '1'; -- C is already fully specified X := '1'; -- X is assigned when COND1 is TRUE
  else
    B := '0'; -- B is assigned when COND1 is FALSE
  end if;
  -- B is assigned under all branches of if (COND1),
  -- that is, both when COND1 is TRUE and when
  -- COND1 is FALSE, so B is fully specified.
  -- C is assigned regardless of COND1, so C is fully
  -- specified. (The second assignment to C does
  -- not change this.)
```

```
-- X is not assigned under all branches of
-- if (COND1), namely, when COND1 is FALSE,
-- so X is not fully specified.
end process;
...
```

The conditions of each if and else statement are considered independent in Example 3-7.

In Example 3-8, variable A is not fully specified.

#### Example 3-8 Variable A Is Not Fully Specified

```
if (COND1) then
    A <= '1';
end if;

if (not COND1) then
    A <= '0';
end if;</pre>
```

A variable or signal that is not fully specified is considered conditionally specified, and Presto VHDL infers a latch to store the variable value. You can conditionally assign a variable, but you cannot read a conditionally specified variable. You can, however, both conditionally assign and read a signal.

If a fully specified variable is read before its assignment statements, combinational feedback might exist. For example, the following fragment synthesizes combinational feedback for VAL.

```
process(D, LOAD)
  variable VAL: BIT;
begin
  if (LOAD = '1') then
    VAL := D;
  else
    VAL := VAL;
  end if;
  VAL_OUT <= VAL;
end process;</pre>
```

In a combinational process, you can ensure that a variable or signal is fully specified, by providing an initial (default) assignment to the variable at the beginning of the process. This default assignment ensures that the variable is always assigned a value, regardless of conditions. Subsequent assignment statements can override the default. A default assignment is made to variables A and C in Example 3-7.

Another way to ensure that you do not imply combinational feedback is to use a sequential process (one with a wait or if signal'event statement). In such a case, variables and signals are registered. The registers break the combinational feedback loop.

Presto VHDL infers latches for incompletely specified case statements that use an others clause, where the others clause covers more than one value. To avoid latch inference, use a default statement before the case statements.

# 4

## Modeling Sequential Logic

This chapter contains the following sections, which describe how to infer latches and flip-flops:

- Generic Sequential Cells (SEQGENs)
- Inference Reports for Flip-Flops and Latches
- Register Inference Variables
- Register Inference Attributes
- Inferring D and Set/Reset (SR) Latches
- Inferring D Flip-Flops
- Inferring JK Flip-Flops
- Inferring Master-Slave Latches
- Limitations of Register Inference
- Unloaded Sequential Cell Preservation

## **Generic Sequential Cells (SEQGENs)**

When Presto VHDL reads a design, it uses generic sequential cells (SEQGENs), shown in Figure 4-1, to represent inferred flip-flops and latches.

Figure 4-1 SEQGEN Cell and Pin Assignments



To illustrate how Presto VHDL uses SEQGENs to implement a flip-flop, consider Example 4-1. This code infers a D flip-flop with an asynchronous reset.

#### Example 4-1 D Flip-Flop With Asynchronous Reset

```
library IEEE;
use IEEE.std_logic_1164.all;
entity dff_async_reset is
 port (DATA, CLK, RESET : in std_logic;
        Q : out std logic );
end dff_async_reset;
architecture rtl of dff_async_reset is
begin
process ( CLK, RESET) begin
  if (RESET = '1') then
    Q <= '0';
  elsif (CLK'event and CLK = '1') then
    Q <= DATA;
  end if;
end process;
end rtl;
```

Figure 4-2 shows the SEQGEN implementation.

Figure 4-2 D Flip-flop With an Asynchronous Reset: Presto VHDL SEQGEN Implementation



After Design Compiler compiles the design, SEQGENs are mapped to the appropriate latch or flip-flop in the technology library. Figure 4-3 shows an example implementation after compile.

Figure 4-3 D Flip-flop with an Asynchronous Reset: Design Compiler Implementation



#### Note:

If the technology library does not contain the specific inferred flip-flop or latch, Design Compiler creates combinational logic for the missing function, if possible. For example, if you infer a D flip-flip with a synchronous set but your target technology library does not contain this type of flip-flop, Design Compiler will create combinational logic for the synchronous set function. Design Compiler cannot create logic to duplicate an asynchronous preset/reset. Your library must contain the sequential cell with the asynchronous control pins.

## Inference Reports for Flip-Flops and Latches

Presto VHDL provides inference reports that describe each inferred flip-flop or latch. You can enable or disable the generation of inference reports by using the hdlin\_reporting\_level variable. By default, hdlin\_reporting\_level is set to basic. When hdlin\_reporting\_level is set to basic or comprehensive, Presto Verilog generates a report similar to Example 4-2. This basic inference report shows only which type of register was inferred.

Example 4-2 Inference Report for a D Flip-Flop With Asynchronous Reset

| Register Name | <br>  Type | Width    | Bus   : | MB   AR | AS   SR | =======<br>  SS   ST |  |
|---------------|------------|----------|---------|---------|---------|----------------------|--|
| Q_reg         | Flip-flop  | 1<br>  1 | N   :   | N   Y   | N   N   | N   N                |  |

In the report, the columns are abbreviated as follows:

- MB represents multibit cell
- AR represents asynchronous reset
- AS represents asynchronous set
- SR represents synchronous reset
- SS represents synchronous set
- ST represents synchronous toggle

A "Y" in a column indicates that the respective control pin was inferred for the register; an "N" indicates that the respective control pin was not inferred for the register. For a D flip-flop with an asynchronous reset, there should be a "Y" in the AR column. The report also indicates the type of register inferred, latch or flip-flop, and the name of the inferred cell.

When the hdlin\_reporting\_level variable is set to verbose, the report indicates how each pin of the SEQGEN cell is assigned, along with which type of register was inferred. Example 4-3 shows a verbose inference report.

Example 4-3 Verbose Inference Report for a D Flip-Flop With Asynchronous Reset

| ======================================= |           | ======= | =======  | ========    | =========    |
|-----------------------------------------|-----------|---------|----------|-------------|--------------|
| Register Name                           | Type      | Width   | Bus   M  | B   AR   AS | SR   SS   ST |
| <br>  Q_reg                             | Flip-flop | 1       | N   N    | Y   N       | N   N   N    |
|                                         |           | ======  | ======== | =========   | ==========   |

Sequential Cell (Q\_reg)

Cell Type: Flip-Flop

Multibit Attribute: N

Clock: CLK

Async Clear: RESET

Chapter 4: Modeling Sequential Logic Inference Reports for Flip-Flops and Latches

```
Async Set: 0
Async Load: 0
Sync Clear: 0
Sync Set: 0
Sync Toggle: 0
Sync Load: 1
```

If you do not want inference reports, set hdlin\_reporting\_level to none. For more information about the hdlin\_reporting\_level variable, see "Elaboration Reports" on page 1-7.

## **Register Inference Variables**

The variables in Table 4-1 control register inference. These are set before the design is read and apply to all applicable cells in the design. Use of these variables may have unintended consequences. For example, when the hdlin\_ff\_always\_sync\_set\_reset variable is set to true, Presto VHDL treats every signal in every process as though the sync\_set\_reset directive is attached to it. Therefore, it checks all processes for all constant (0 or 1) assignments for a register input. The control for these constant-assigned signals becomes part of the set/reset logic.

Table 4-1 Variables That Control Register Inference

| Variable                                                   | Description                                                                                                                                                                                                                                                         |
|------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hdlin_keep_feedback (Default is false.)                    | When this variable is true, Presto VHDL keeps all flip-flop feedback loops.                                                                                                                                                                                         |
|                                                            | When this variable is false, Presto VHDL removes all flip-flop feedback loops. For example, Presto VHDL removes feedback loops inferred from a statement such as Q=Q. Removing the state feedback from a simple D flip-flop creates a synchronous loaded flip-flop. |
| hdlin_ff_always_<br>sync_set_reset<br>(Default is false.)  | When this variable is true, Presto VHDL attempts to infer synchronous set and reset conditions for all flip-flops.                                                                                                                                                  |
| hdlin_ff_always_<br>async_set_reset<br>(Default is false.) | When this variable is true, Presto VHDL attempts to infer asynchronous set and reset conditions for all flip-flops.                                                                                                                                                 |

## **Register Inference Attributes**

Use the attributes in Table 4-2 to direct Presto VHDL to the type of sequential device you want inferred. Attributes are added to the RTL on specific processes.

Table 4-2 Attributes for Controlling Register Inference

| Attribute                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| async_set_reset            | When a single-bit signal has this attribute set to true, Presto VHDL searches for a branch that uses the signal as a condition and then checks whether the branch contains an assignment to a constant value. If the branch does, the signal becomes an asynchronous reset or set. See Example 4-4 on page 4-8, Example 4-11 on page 4-11, and Example 4-13 on page 4-12. Attach this attribute to 1-bit signals by using the following syntax: |
|                            | <pre>attribute async_set_reset of signal_name_list: signal is "true";</pre>                                                                                                                                                                                                                                                                                                                                                                     |
| async_set_reset_local      | VHDL Compiler treats listed signals in the specified process as if they have the <code>async_set_reset</code> attribute set to true.                                                                                                                                                                                                                                                                                                            |
|                            | Attach this attribute to a process label by using the following syntax: attribute async_set_reset_local of process_label : label is "signal_name_list";                                                                                                                                                                                                                                                                                         |
| async_set_reset_local_a    | VHDL Compiler treats all signals in the specified processes as if they have the <code>async_set_reset</code> attribute set to true.                                                                                                                                                                                                                                                                                                             |
|                            | Attach this attribute to process labels by using the following syntax: attribute async_set_reset_local_all of process_label_list : label is "true";                                                                                                                                                                                                                                                                                             |
| sync_set_reset             | When a single-bit signal has this attribute set to true, Presto VHDL checks the signal to determine whether it synchronously sets or resets a register in the design. See Example 4-33 on page 4-22 and Example 4-35 on page 4-24. Attach this attribute to 1-bit signals by using the following syntax:  attribute sync_set_reset of signal_name_list: signal is "true";                                                                       |
| sync_set_reset_local       | VHDL Compiler treats listed signals in the specified process as if they                                                                                                                                                                                                                                                                                                                                                                         |
| -1 <u>-000_10000_10041</u> | have the sync_set_reset attribute set to true.                                                                                                                                                                                                                                                                                                                                                                                                  |
|                            | Attach this attribute to a process label by using the following syntax: attribute sync_set_reset_local of process_label : label is "signal_name_list";                                                                                                                                                                                                                                                                                          |

Table 4-2 Attributes for Controlling Register Inference (Continued)

| Attribute                 | Description                                                                                                                                                                                                                                                                                                                                                                               |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| sync_set_reset_local _all | VHDL Compiler treats all signals in the specified processes as if they have the sync_set_reset attribute set to true.                                                                                                                                                                                                                                                                     |
|                           | Attach this attribute to process labels by using the following syntax: attribute sync_set_reset_local_all of process_label_list : label is "true";                                                                                                                                                                                                                                        |
| one_cold<br>one_hot       | These attributes prevent Presto VHDL from implementing priority-encoding logic for the set and reset signals and are useful if you know your design has a one-hot or one-cold implementation. See Example 4-15 on page 4-13, Example 4-31 on page 4-21, and Example 4-43 on page 4-31. Attach the attributes to set or reset signals on sequential devices by using the following syntax: |
|                           | attribute one_cold signal_name_list: signal is "true"; or attribute one_hot signal_name_list: signal is "true";                                                                                                                                                                                                                                                                           |
|                           | You might want to add an assertion to the VHDL code to ensure that the group of signals has a one-cold or one-hot implementation. Presto VHDL does not produce any logic to check this assertion.                                                                                                                                                                                         |
| clocked_on_also           | This attribute is set with the set_signal_type command in an embedded Design Compiler script and used for master-slave inference. See "Inferring Master-Slave Latches" on page 4-32.                                                                                                                                                                                                      |

## Inferring D and Set/Reset (SR) Latches

This section describes how to infer SR and D latches, in the following subsections:

- Inferring SR Latches
- Inferring D Latches
- Limitations of D Latch Inference

## **Inferring SR Latches**

Use SR latches with caution, because they are difficult to test. Design Compiler does not ensure that the logic driving the inputs is hazard-free, so you must verify that the inputs are hazard-free and do not glitch.

Example 4-4 provides the VHDL code that implements the SR latch described in the truth table in Table 4-3. Example 4-5 shows the inference report generated by Presto VHDL.

Table 4-3 SR Latch Truth Table (NAND Type)

| Set | Reset | у          |
|-----|-------|------------|
| 0   | 0     | Not stable |
| 0   | 1     | 1          |
| 1   | 0     | 0          |
| 1   | 1     | у          |

## Example 4-4 SR Latch

```
library IEEE, synopsys;
use IEEE.std_logic_1164.all;
use synopsys.attributes.all;
entity sr_latch is
 port (SET, RESET : in std_logic;
        Q : out std_logic );
 attribute async_set_reset of SET, RESET :
   signal is "true";
end sr_latch;
architecture rtl of sr_latch is
begin
process (SET, RESET) begin
 if (SET = '0') then
   Q <= '1';
  elsif (RESET = '0') then
   Q <= '0';
  end if;
end process;
end rtl;
```

## Example 4-5 Inference Report for an SR Latch

| Register Name | Type  | ======<br>Width | Bus | =====<br>  MB | AR | AS | SR        | =====<br>  SS<br> | =====<br>  ST | = |
|---------------|-------|-----------------|-----|---------------|----|----|-----------|-------------------|---------------|---|
| Q_reg         | Latch | 1               | N   | N             | Y  | Y  | <br>-<br> | <br>  -<br>       | -<br>  -      |   |

```
Sequential Cell (Q_reg)
Cell Type: Latch
Multibit Attribute: N
Clock: 0
```

```
Async Clear: RESET'
Async Set: SET'
Async Load: 0
```

## **Inferring D Latches**

The following sections provide code examples and inference reports for D latches:

- Overview—Latch Inference
- Basic D Latch
- D Latch With Asynchronous Set
- D Latch With Asynchronous Reset
- D Latch With Asynchronous Set and Reset

## Overview—Latch Inference

When you do not specify a variables value under all conditions, such as an incompletely specified if statement, Presto VHDL infers a D latch.

For example, the if statement in Example 4-6 infers a D latch, because there is no else clause. The resulting value for output Q is specified only when input enable has a logic 1 value. As a result, output Q becomes a latched value.

#### Example 4-6 Latch Inference

```
process(DATA, GATE) begin
  if (GATE = '1') then
   Q <= DATA;
  end if;
end process;</pre>
```

To avoid latch inference, assign a value to the signal under all conditions, as shown in Example 4-7.

#### Example 4-7 Fully Specified Signal: No Latch Inference

```
process(DATA, GATE) begin
  if (GATE = '1') then
   Q <= DATA;
  else
   Q <= '0';
  end if;
end process;</pre>
```

Variables declared locally within a subprogram do not hold their value over time, because each time a subprogram is called, its variables are reinitialized. Therefore, Presto VHDL does not infer latches for variables declared in subprograms. In Example 4-8, Presto VHDL does not infer a latch for output Q.

#### Example 4-8 Function: No Latch Inference

```
function MY_FUNC(DATA, GATE : std_logic) return std_logic is
    variable STATE: std_logic;
begin
  if (GATE = '1') then
    STATE := DATA;
  end if;
  return STATE;
end;
. . .
Q <= MY_FUNC(DATA, GATE);</pre>
```

## **Basic D Latch**

When you infer a D latch, make sure you can control the gate and data signals from the top-level design ports or through combinational logic. Controllable gate and data signals ensure that simulation can initialize the design.

Example 4-9 provides the VHDL template for a D latch. Presto VHDL generates the verbose inference report shown in Example 4-10.

#### Example 4-9 Basic D Latch

```
library IEEE;
use IEEE.std_logic_1164.all;
entity d_latch is
  port (GATE, DATA: in std_logic;
       Q: out std_logic);
end d_latch;

architecture rtl of d_latch is
begin
process (GATE, DATA) begin
  if (GATE = '1') then
       Q <= DATA;
  end if;
end process;
end rtl:</pre>
```

#### Example 4-10 Verbose Inference Report for a D Latch

| ======================================= | ======            | ======= | ======        |              |    | ===== | ===== | =====     | =====     | =     |
|-----------------------------------------|-------------------|---------|---------------|--------------|----|-------|-------|-----------|-----------|-------|
| Register Name                           | Type              | Width   | Bus           | MB           | AR | AS    | SR    | SS        | ST        |       |
|                                         | ======<br>  Latch | 1       | ======<br>  N | =====<br>  N | N  | N     | -     | ====:<br> | =====<br> | =<br> |

\_\_\_\_\_\_

```
Sequential Cell (Q_reg)
Cell Type: Latch
Multibit Attribute: N
Clock: 0
Async Clear: 0
Async Set: 0
Async Load: GATE
```

## **D Latch With Asynchronous Set**

Use the async\_set\_reset attribute to specify the asynchronous set or reset controls. Presto VHDL examines the polarity of the constants assigned to the signals with the async\_set\_reset attribute to determine if the signal is an AR ('0') or an AS ('1').

Example 4-11 provides the VHDL template for a D latch with an asynchronous set. Presto VHDL generates the verbose inference report shown in Example 4-12.

#### Example 4-11 D Latch With Asynchronous Set

```
library IEEE, synopsys;
use IEEE.std_logic_1164.all;
use synopsys.attributes.all;
entity d_latch_async_set is
  port (GATE, DATA, SET : in std_logic;
        Q : out std logic );
  attribute async_set_reset of SET :
    signal is "true";
end d_latch_async_set;
architecture rtl of d_latch_async_set is
process (GATE, DATA, SET) begin
  if (SET = '0') then
    Q <= '1';
  elsif (GATE = '1') then
    O <= DATA;
  end if:
end process;
end rtl;
```

## Example 4-12 Verbose Inference Report for a D Latch With Asynchronous Set

```
| Register Name | Type | Width | Bus | MB | AR | AS | SR | SS | ST |
| Q_reg | Latch | 1 | N | N | N | Y | - | - | - |
| Sequential Cell (Q_reg)
| Cell Type: Latch
```

```
Multibit Attribute: N
Clock: 0
Async Clear: 0
Async Set: SET'
Async Load: GATE
```

## D Latch With Asynchronous Reset

Use the async set reset attribute to specify asynchronous set or reset controls.

Example 4-13 provides the VHDL template for a D latch with an asynchronous reset. Presto VHDL generates the verbose inference report shown in Example 4-14.

#### Example 4-13 D Latch With Asynchronous Reset

```
library IEEE, synopsys;
use IEEE.std_logic_1164.all;
use synopsys.attributes.all;
entity d_latch_async_reset is
  port (GATE, DATA, RESET : in std_logic;
        Q : out std logic );
  attribute async_set_reset of RESET :
    signal is "true";
end d_latch_async_reset;
architecture rtl of d_latch_async_reset is
process (GATE, DATA, RESET) begin
  if (RESET = '0') then
    Q <= '0';
  elsif (GATE = '1') then
    O <= DATA;
  end if:
end process;
end rtl;
```

#### Example 4-14 Inference Report for D Latch With Asynchronous Reset

```
Register Name | Type | Width | Bus | MB | AR | AS | SR | SS | ST |

| Q_reg | Latch | 1 | N | N | Y | N | - | - | - |

Sequential Cell (Q_reg)
Cell Type: Latch
Multibit Attribute: N
Clock: 0
Async Clear: RESET'
Async Set: 0
Async Load: GATE
```

## D Latch With Asynchronous Set and Reset

Example 4-15 provides the VHDL template for a D latch with an active-low asynchronous set and reset. This template uses the async\_set\_reset attribute to direct Presto VHDL to the asynchronous signals in the process.

The template in Example 4-15 uses the <code>one\_cold</code> attribute to prevent priority encoding of the set and reset signals. If you do not specify the <code>one\_cold</code> attribute, the set signal has priority, because it is used as the condition for the if clause. Use <code>one\_cold</code> for active-low signals and <code>one\_hot</code> for active-high signals. Example 4-16 shows the verbose inference report.

## Example 4-15 D Latch With Asynchronous Set and Reset

```
library IEEE, synopsys;
use IEEE.std logic 1164.all;
use synopsys.attributes.all;
entity d_latch_async is
 port (GATE, DATA, SET, RESET :in std_logic;
       Q : out std logic );
  attribute one_cold of SET, RESET :
    signal is "true";
end d latch async;
architecture rtl of d_latch_async is
  attribute async_set_reset of SET, RESET :
    signal is "true";
begin
process (GATE, DATA, SET, RESET) begin
  if (SET = '0') then
    0 <= '1';
  elsif (RESET = '0') then
    Q <= '0';
  elsif (GATE = '1') then
    O <= DATA;
  end if:
end process;
end rtl;
```

#### Example 4-16 Inference Report for D Latch With Asynchronous Set and Reset

```
Register Name | Type | Width | Bus | MB | AR | AS | SR | SS | ST |

| Q_reg | Latch | 1 | N | N | Y | Y | - | - | - |

Sequential Cell (Q_reg)
Cell Type: Latch
Multibit Attribute: N
Clock: 0
Async Clear: RESET'
Async Set: SET'
Async Load: GATE
```

## **Limitations of D Latch Inference**

A variable must always have a value before it is read. As a result, you cannot read a conditionally assigned variable after the if statement in which it is assigned. A conditionally assigned variable is assigned a new value under some, but not all, conditions. Example 4-17 shows an invalid use of the conditionally assigned variable VALUE.

#### Example 4-17 Invalid Use of a Conditionally Assigned Variable

```
signal X, Y : std_logic;
. . .
process
  variable VALUE : std_logic;
begin

if (condition) then
   VALUE := X;
end if;

Y <= VALUE; -- Invalid read of variable VALUE
end;</pre>
```

## **Inferring D Flip-Flops**

The following subsections describe various types of D flip-flop inference:

- Overview—Inferring D Flip-Flops
- Enabling Conditions in if Statements
- Positive-Edge-Triggered D Flip-Flop
- Negative-Edge-Triggered D Flip-Flop
- D Flip-Flop With Asynchronous Set
- D Flip-Flop With Asynchronous Reset
- D Flip-Flop With Asynchronous Set and Reset
- D Flip-Flop With Synchronous Set
- D Flip-Flop With Synchronous Reset
- D Flip-Flop With Complex Set/Reset Signals
- D Flip-Flop With Synchronous and Asynchronous Load
- Multiple Flip-Flops: Asynchronous and Synchronous Controls

## **Overview—Inferring D Flip-Flops**

Presto VHDL infers a D flip-flop whenever the condition of a wait or if statement uses an edge expression. Use the following syntax to describe a rising edge:

```
SIGNAL'event and SIGNAL = '1'
```

Use the following syntax to describe a falling edge:

```
SIGNAL'event and SIGNAL = '0'
```

If you are using the IEEE std\_logic\_1164 package, you can use the following syntax to describe a rising edge and a falling edge:

```
if (rising_edge (CLK)) then
if (falling_edge (CLK)) then
```

You can use the following syntax for a bused clock. You can also use a member of a bus as a signal.

```
sig(3)'event and sig(3) = '1'
rising_edge (sig(3))
```

If possible, use the if statement, because it provides greater control over the inferred registers. Only one wait statement per process is allowed.

In a process that models sequential logic, Presto VHDL allows statements to precede or to follow the if statement as long as no statement following the if statement tries to write a value that is assigned within the if statement. See Example 4-18.

#### Example 4-18 Presto VHDL Supports Statements Preceding and Following if ck'EVENT

```
P: process (ck)
  variable X, Y: BIT;
begin
  Y := not D; -- assignment before the if statement
  if ck'EVENT and ck = '1' then
   X := D;
  end if;
  Q <= X and Y; -- assignment after the if statement
  end process;</pre>
```

There are cases in which statements appearing before the if statement would make the code unsynthesizable. Specifically, when the statements preceding the if statement writes to a variable that was also written to within the if body, as shown in Example 4-19, the code would not be synthesizable.

## Example 4-19 Code Cannot Be Synthesized—if ck'EVENT Statement Writes to a Variable Written to in Body

```
P: process (ck)
  variable X: BIT;
begin
  X := D1;
  if ck'EVENT and CK = '1' then
   X := D2; -- conflicts with previous assignment end if;
  Q <= X;
end process;</pre>
```

## **Enabling Conditions in if Statements**

Presto VHDL allows conditions in the test of the if statement that are not part of the clock edge test. When other conditions appear in the test, Presto VHDL synthesizes them by assuming they are enable conditions. Presto VHDL also recognizes permutations of the conditions in the if statement. Example 4-20 shows the coding style supported by Presto VHDL.

## Example 4-20 Presto VHDL Supports Enabling Expressions in if Statements

```
process (ck)
begin
  if (ck = '1' and en = '1' and ck'EVENT) then
    --sequential_statements
  end if;
end process;
```

## Positive-Edge-Triggered D Flip-Flop

When you infer a D flip-flop, make sure you can control the clock and data signals from the top-level design ports or through combinational logic. Controllable clock and data signals ensure that simulation can initialize the design. If you cannot control the clock and data signals, infer a D flip-flop with asynchronous reset or set, or with synchronous reset or set.

Example 4-21 uses the 'event attribute and Example 4-22 uses the rising\_edge function to code a positive-edge-triggered D flip-flop. Example 4-23 shows the verbose inference report.

#### Example 4-21 Positive-Edge-Triggered D Flip-Flop Using 'event Attribute

```
library IEEE ;
use IEEE.std_logic_1164.all;
entity dff_pos is
  port (DATA, CLK : in std_logic;
       Q : out std_logic );
end dff_pos;

architecture rtl of dff_pos is
begin
process (CLK) begin
  if (CLK'event and CLK = '1') then
       Q <= DATA;
  end if;
end process;
end rtl;</pre>
```

## Example 4-22 Positive-Edge-Triggered D Flip-Flop Using rising\_edge

```
library IEEE;
use IEEE.std_logic_1164.all;

entity dff_pos is
   port (DATA, CLK : in std_logic;
        Q : out std_logic );
end dff_pos;
architecture rtl of dff_pos is
begin
process (CLK) begin
   if (rising_edge (CLK)) then
        Q <= DATA;
   end if;
end process;
end rtl;</pre>
```

#### Example 4-23 Inference Report for Positive-Edge-Triggered D Flip-Flop

Async Load: 0

```
Sync Clear: 0
Sync Set: 0
Sync Toggle: 0
Sync Load: 1
```

## **Negative-Edge-Triggered D Flip-Flop**

Example 4-24 uses the 'event attribute and Example 4-25 uses the falling\_edge function to code a negative-edge-triggered D flip-flop.

Presto VHDL generates the verbose inference report shown in Example 4-26.

## Example 4-24 Negative-Edge-Triggered D Flip-Flop Using 'event

```
library IEEE;
use IEEE.std_logic_1164.all;
entity dff_neg is
  port (DATA, CLK : in std_logic;
       Q : out std_logic );
end dff_neg;

architecture rtl of dff_neg is
begin
process (CLK) begin
  if (CLK'event and CLK = '0') then
       Q <= DATA;
  end if;
end process;
end rtl;</pre>
```

## Example 4-25 Negative-Edge-Triggered D Flip-Flop Using falling\_edge

```
library IEEE;
use IEEE.std_logic_1164.all;
entity dff_neg is
  port (DATA, CLK : in std_logic;
       Q : out std_logic );
end dff_neg;

architecture rtl of dff_neg is
begin
process (CLK) begin
  if (falling_edge (CLK)) then
    Q <= DATA;
  end if;
end process;
end rtl;</pre>
```

Example 4-26 Inference Report for Negative-Edge-Triggered D Flip-Flop

```
______
| Register Name | Type | Width | Bus | MB | AR | AS | SR | SS | ST |
_____
   ______
Sequential Cell (Q_reg)
    Cell Type: Flip-Flop
    Multibit Attribute: N
    Clock: CLK'
    Async Clear: 0
    Async Set: 0
    Async Load: 0
    Sync Clear: 0
    Sync Set: 0
    Sync Toggle: 0
    Sync Load: 1
```

## **D Flip-Flop With Asynchronous Set**

Example 4-27 provides the VHDL template for a D flip-flop with an asynchronous set. Presto VHDL generates the verbose inference report shown in Example 4-28.

#### Example 4-27 D Flip-Flop With Asynchronous Set

```
library IEEE;
use IEEE.std_logic_1164.all;
entity dff_async_set is
  port (DATA, CLK, SET : in std_logic;
        Q : out std_logic );
end dff_async_set;

architecture rtl of dff_async_set is
begin
process (CLK, SET) begin
  if (SET = '0') then
    Q <= '1';
  elsif (CLK'event and CLK = '1') then
    Q <= DATA;
  end if;
end process;
end rtl;</pre>
```

#### Example 4-28 Inference Report for a D Flip-Flop With Asynchronous Set

| Register Name          | <br>  Type | Width | ========<br>  Bus   M | ib   Ar | =====<br>  AS | SR   SS | ====<br>  ST |
|------------------------|------------|-------|-----------------------|---------|---------------|---------|--------------|
| Q_reg                  | Flip-flop  | 1     | N   N                 | N       | Y             | N   N   | N  <br>===== |
| Sequential Cell (Q_reg | )          |       |                       |         |               |         |              |

```
Cell Type: Flip-Flop
Multibit Attribute: N
Clock: CLK
Async Clear: 0
Async Set: SET'
Async Load: 0
Sync Clear: 0
Sync Set: 0
Sync Toggle: 0
Sync Load: 1
```

## D Flip-Flop With Asynchronous Reset

Example 4-29 provides the VHDL template for a D flip-flop with an asynchronous reset. Presto VHDL generates the verbose inference report shown in Example 4-30.

## Example 4-29 D Flip-Flop With Asynchronous Reset

```
library IEEE;
use IEEE.std_logic_1164.all;
entity dff_async_reset is
 port (DATA, CLK, RESET : in std_logic;
        Q : out std_logic );
end dff async reset;
architecture rtl of dff_async_reset is
begin
process ( CLK, RESET) begin
  if (RESET = '1') then
    Q <= '0';
  elsif (CLK'event and CLK = '1') then
    Q <= DATA;
  end if;
end process;
end rtl;
```

#### Example 4-30 Inference Report for a D Flip-Flop With Asynchronous Reset

```
Register Name | Type | Width | Bus | MB | AR | AS | SR | SS | ST |

| Q_reg | Flip-flop | 1 | N | N | Y | N | N | N | N | N |

Sequential Cell (Q_reg)
Cell Type: Flip-Flop
Multibit Attribute: N
Clock: CLK
Async Clear: RESET
Async Set: 0
Async Load: 0
Sync Clear: 0
```

```
Sync Set: 0
Sync Toggle: 0
Sync Load: 1
```

## D Flip-Flop With Asynchronous Set and Reset

Example 4-31 provides the VHDL template for a D flip-flop with active-high asynchronous set and reset pins.

The template in Example 4-31 uses the <code>one\_hot</code> attribute to prevent priority encoding of the set and reset signals. If you do not specify the <code>one\_hot</code> attribute, the reset signal has priority, because it is used as the condition for the if clause. The <code>one\_cold</code> attribute would be used instead of the <code>one\_hot</code> if you had active-low signals. Presto VHDL generates the verbose inference report shown in Example 4-32.

## Example 4-31 D Flip-Flop With Asynchronous Set and Reset

```
library IEEE, synopsys;
use IEEE.std_logic_1164.all;
use synopsys.attributes.all;
entity dff_async is
 port (DATA, CLK, SET, RESET : in std_logic;
       Q : out std_logic );
 attribute one_hot of SET, RESET : signal is "true";
end dff_async;
architecture rtl of dff_async is
process (CLK, SET, RESET) begin
 if (RESET = '1') then
   0 <= '0';
 elsif (SET = '1') then
   Q <= '1';
  elsif (CLK'event and CLK = '1') then
   Q <= DATA;
 end if:
end process;
end rtl;
```

#### Example 4-32 Inference Report for a D Flip-Flop With Asynchronous Set and Reset

| Register Name | <br>  Type | ======<br>  Width | Bus | =====<br>  MB | =====<br>  AR | AS         | SR         | SS         | =====<br>  ST<br> |  |
|---------------|------------|-------------------|-----|---------------|---------------|------------|------------|------------|-------------------|--|
|               | Flip-flop  | <br>  1<br>====== | N   | N<br>=====    | Y<br>=====    | Y<br>===== | N<br>===== | N<br>===== | N<br>=====        |  |

```
Sequential Cell (Q_reg)
Cell Type: Flip-Flop
Multibit Attribute: N
Clock: CLK
Async Clear: RESET
Async Set: SET
Async Load: 0
Sync Clear: 0
```

```
Sync Set: 0
Sync Toggle: 0
Sync Load: 1
```

## **D Flip-Flop With Synchronous Set**

Use the <code>sync\_set\_reset</code> pragma to infer a D flip-flop with a synchronous set/reset. When you compile your design, the SEQGEN inferred by Presto VHDL will be either

- Mapped to a flip-flop in the technology library with a synchronous set/reset pin or
- Mapped to a regular D flip-flop. In this case, Design Compiler builds synchronous set/ reset logic in front of the D pin.

The choice depends on which method provides a better optimization result.

It is important to use the <code>sync\_set\_reset</code> pragma to label the set/reset signal. This pragma tells Design Compiler that the signal should be kept as close to the register as possible during mapping, preventing a simulation/synthesis mismatch which can occur if the set/reset signal is masked by an X during initialization in simulation.

Example 4-33 shows the recommended coding style for a synchronous set/reset flip-flop,using the <code>sync\_set\_reset</code> pragma. Presto VHDL generates the verbose inference report shown in Example 4-34

## Example 4-33 D Flip-Flop With Synchronous Set

```
library IEEE, synopsvs;
use IEEE.std_logic_1164.all;
use synopsys.attributes.all;
entity dff_sync_set is
  port (DATA, CLK, SET : in std_logic;
       Q : out std_logic );
  attribute sync_set_reset of SET : signal is "true";
end dff_sync_set;
architecture rtl of dff sync set is
process (CLK) begin
  if (CLK'event and CLK = '1') then
    if (SET = '1') then
      Q <= '1';
    else
      O <= DATA;
    end if;
  end if;
end process;
end rtl;
```

Example 4-34 Inference Report for a D Flip-Flop With Synchronous Set

| ======================================                                                                                                                             | Type                     | ======<br>  Width | Bus | =====<br>  MB | =====<br>  AR | =====<br>AS | SR | SS | ====<br>  ST |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-------------------|-----|---------------|---------------|-------------|----|----|--------------|
| Q_reg                                                                                                                                                              | Flip-flop                | <br>  1           | N   | N             | N             | N           | N  | Y  | N            |
| Sequential Cell (Q_reg) Cell Type: Fl: Multibit Attr: Clock: CLK Async Clear: 0 Async Set: 0 Async Load: 0 Sync Clear: 0 Sync Set: SET Sync Toggle: 0 Sync Load: 1 | ip-Flop<br>ibute: N<br>0 |                   |     |               |               |             |    |    |              |

## **D Flip-Flop With Synchronous Reset**

Use the <code>sync\_set\_reset</code> pragma to infer a D flip-flop with a synchronous set/reset. When you compile your design, the SEQGEN inferred by Presto VHDL will be mapped to a flip-flop in the technology library with a synchronous set/reset pin or Design Compiler will use a regular D flip-flop and build synchronous set/reset logic in front of the D pin. The choice depends on which method provides a better optimization result.

It is important to use the <code>sync\_set\_reset</code> pragma to label the set/reset signal. This pragma tells Design Compiler that the signal should be kept as close to the register as possible during mapping, preventing a simulation/synthesis mismatch which can occur if the set/reset signal is masked by an X during initialization in simulation.

Example 4-35 shows the recommended coding style for a synchronous set/reset flip-flop using the <code>sync\_set\_reset</code> pragma. Presto VHDL generates the verbose inference report shown in Example 4-36.

#### Example 4-35 D Flip-Flop With Synchronous Reset

```
library IEEE, synopsys;
use IEEE.std_logic_1164.all;
use synopsys.attributes.all;
entity dff_sync_reset is
 port (DATA, CLK, RESET : in std_logic;
        Q : out std_logic );
  attribute sync_set_reset of RESET :
    signal is "true";
end dff_sync_reset;
architecture rtl of dff_sync_reset is
process (CLK) begin
  if (CLK'event and CLK = '1') then
    if (RESET = '0') then
      Q <= '0';
    else
      Q <= DATA;
    end if;
  end if;
end process;
end rtl;
```

## Example 4-36 Inference Report for a D Flip-Flop With Synchronous Reset

```
______
Register Name | Type | Width | Bus | MB | AR | AS | SR | SS | ST |
______
Q_reg | Flip-flop | 1 | N | N | N | N | N | N | N |
Sequential Cell (Q_reg)
    Cell Type: Flip-Flop
    Multibit Attribute: N
    Clock: CLK
    Async Clear: 0
    Async Set: 0
    Async Load: 0
     Sync Clear: RESET'
     Sync Set: 0
     Sync Toggle: 0
     Sync Load: 1
```

## D Flip-Flop With Complex Set/Reset Signals

While many set/reset signals are simple signals, some include complex logic. To enable Presto to generate a clean set/reset (that is, one attached to only the appropriate set/reset pin), use the following coding guidelines:

• Apply the appropriate set/reset attribute ( sync\_set\_reset or async\_set\_reset) to the set/reset signal. For example,

- Use no more than two operands in the set/reset logic expression conditional.
- Use the set/reset signal as the first operand in the set/reset logic expression conditional.

This coding style supports usage of the negation operator on the set/reset signal and the logic expression. The logic expression can be a simple expression or any expression contained inside parentheses. However, any deviation from these coding guidelines will not be supported. For example, the following coding styles are not supported: using a subscripted value as reset, using a more complex expression other than the OR of two expressions, or using a rst (or ~rst) that does not appear as the first argument in the expression.

#### Examples:

```
process(...)
  if (rst='1' OR logic_expression)
    q <= 0;
  else ...
  else ...

a <= rst OR NOT( a | b & c);
process(...)
  if (a)
  q = 0;
  else ...;
  else ...;
else ...;</pre>
```

```
process(...)
if ( NOT rst OR NOT (a OR b OR c))
q = 0;
else ...
else ...
```

## D Flip-Flop With Synchronous and Asynchronous Load

To infer a component with both synchronous and asynchronous controls, you must check the asynchronous conditions before you check the synchronous conditions.

Example 4-37 provides the VHDL template for a D flip-flop with a synchronous load (called SLOAD) and an asynchronous load (called ALOAD). Presto VHDL generates the verbose inference report shown in Example 4-38.

## Example 4-37 D Flip-Flop With Synchronous and Asynchronous Load

```
library IEEE;
use IEEE.std_logic_1164.all;
entity dff_a_s_load is
port(SLOAD, ALOAD, ADATA, SDATA, CLK : in std_logic; Q : out std_logic );
end dff a s load;
architecture rtl of dff_a_s_load is
signal asyn_rst, asyn_set :std_logic ;
begin
asyn set <= ALOAD AND (ADATA);
asyn_rst <= ALOAD AND NOT(ADATA);</pre>
process (CLK,asyn_set, asyn_rst)
begin
if (asyn_set ='1') then
0 <= '1';
elsif (asyn_rst ='1') then
q <= '0';
elsif (clk'event and clk ='1' and SLOAD = '1') then Q <= SDATA; end if;
end process;
end rtl:
```

#### Example 4-38 Inference Report for a D Flip-Flop With Synchronous and Asynchronous Load

| Register Name | Type      |   | ======<br>Width<br> | = :<br> <br> - | Bus |  | MB |  | ar<br>Ar |   | AS |   | SR |   | SS | 5 | ====<br>ST | ==<br> <br> |
|---------------|-----------|---|---------------------|----------------|-----|--|----|--|----------|---|----|---|----|---|----|---|------------|-------------|
| Q_reg         | Flip-flop | Ī | 1                   | <br>[          | N   |  | N  |  | <br>У    | Ī | Y  | Ī | N  | Ī | N  | Ī | N          |             |

```
Sequential Cell (Q_reg)
Cell Type: Flip-Flop
Multibit Attribute: N
Clock: CLK
Async Clear: ADATA' ALOAD
Async Set: ADATA ALOAD
Async Load: 0
Sync Clear: 0
Sync Set: 0
Sync Toggle: 0
Sync Load: SLOAD
```

## Multiple Flip-Flops: Asynchronous and Synchronous Controls

If a signal is synchronous in one process but asynchronous in another, set both the sync\_set\_reset and async\_set\_reset attributes on the signal.

In Example 4-39, the <code>infer\_sync</code> process uses the reset signal as a synchronous reset and the <code>infer\_async</code> process uses the reset signal as an asynchronous reset. Example 4-40 shows the verbose inference report.

## Example 4-39 Multiple Flip-Flops: Asynchronous and Synchronous Controls

```
library IEEE, synopsys;
use IEEE.std_logic_1164.all;
use synopsys.attributes.all;
entity multi_attr is
 port (DATA1, DATA2, CLK, RESET, SLOAD : in std_logic;
        Q1, Q2 : out std_logic );
end multi attr;
architecture rtl of multi attr is
  attribute async_set_reset of RESET :
    signal is "true";
  attribute sync_set_reset of RESET :
    signal is "true";
begin
infer_sync: process (CLK) begin
  if (CLK'event and CLK = '1') then
    if (RESET = '0') then
     Q1 <= '0';
    elsif (SLOAD = '1') then
      Q1 <= DATA1;
    end if;
  end if;
end process infer_sync;
infer_async: process (CLK, RESET) begin
  if (RESET = '0') then
    02 <= '0';
```

```
O2 <= DATA2;
    end if;
   end process infer_async;
   end rtl;
Example 4-40 Inference Reports for Example 4-39
Inferred memory devices in process
     in routine multi_attr line 17 in file
        '/remote/vhdl_example/multi_attr.vhd'.
______
Register Name | Type | Width | Bus | MB | AR | AS | SR | SS | ST |
______
______
Inferred memory devices in process
     in routine multi_attr line 27 in file
        '/remote/vhdl_example/multi_attr.vhd'.
______
Register Name | Type | Width | Bus | MB | AR | AS | SR | SS | ST |
______
______
Sequential Cell (Q1_reg)
     Cell Type: Flip-Flop
     Multibit Attribute: N
     Clock: CLK
     Async Clear: 0
     Async Set: 0
     Async Load: 0
     Sync Clear: RESET'
     Sync Set: 0
     Sync Toggle: 0
     Sync Load: SLOAD
Sequential Cell (Q2_reg)
     Cell Type: Flip-Flop
     Multibit Attribute: N
     Clock: CLK
     Async Clear: RESET'
     Async Set: 0
     Async Load: 0
     Sync Clear: 0
     Sync Set: 0
     Sync Toggle: 0
     Sync Load: SLOAD
```

elsif (CLK'event and CLK = '1' and SLOAD = '1') then

## **Inferring JK Flip-Flops**

This section contains code examples and inference reports for the following types of JK flip-flops:

- Basic JK Flip-Flop
- JK Flip-Flop With Asynchronous Set and Reset

## **Basic JK Flip-Flop**

When you infer a JK flip-flop, make sure you can control the J, K, and clock signals from the top-level design ports to ensure that simulation can initialize the design.

Example 4-41 provides the VHDL code that implements the JK flip-flop described in the truth table in Table 4-4.

In the JK flip-flop, the J and K signals act as active-high synchronous set and reset. Use the sync\_set\_reset attribute to indicate that the J and K signals are the synchronous set and reset for the design.

Example 4-42 on page 4-30 shows the verbose inference report generated by Presto VHDL.

Table 4-4 Truth Table for JK Flip-Flop

| J | K | CLK     | Qn+1     |
|---|---|---------|----------|
| 0 | 0 | Rising  | Qn       |
| 0 | 1 | Rising  | 0        |
| 1 | 0 | Rising  | 1        |
| 1 | 1 | Rising  | not (Qn) |
| Χ | X | Falling | Qn       |

## Example 4-41 JK Flip-Flop

```
library IEEE, synopsys;
use IEEE.std_logic_1164.all;
use synopsys.attributes.all;
entity jk is
 port(J, K, CLK : in std_logic;
       Q_out : out std_logic );
  attribute sync set reset of J, K:
    signal is "true";
end jk;
architecture rtl of jk is
  signal Q : std_logic;
begin
process
  variable JK : std_logic_vector ( 1 downto 0);
  wait until (CLK'event and CLK = '1');
  JK := (J \& K);
  case JK is
    when "01" \Rightarrow Q <= '0';
    when "10" => Q <= '1';
    when "11" => Q <= not (Q);
   when "00" => Q <= Q;
   when others => Q <= 'X';
  end case;
end process;
Q_out <= Q;</pre>
end rtl;
```

#### Example 4-42 Inference Report for a JK Flip-Flop

```
______
| Register Name | Type | Width | Bus | MB | AR | AS | SR | SS | ST |
______
Q_reg | Flip-flop | 1 | N | N | N | Y | Y | N |
______
Sequential Cell (Q_reg)
     Cell Type: Flip-Flop
     Multibit Attribute: N
     Clock: CLK
     Async Clear: 0
     Async Set: 0
     Async Load: 0
     Sync Clear: J' K
     Sync Set: J K'
     Sync Toggle: 0
     Sync Load: K
```

## JK Flip-Flop With Asynchronous Set and Reset

Example 4-43 provides the VHDL template for a JK flip-flop with asynchronous set and reset. Use the <code>sync\_set\_reset</code> attribute to indicate the JK function. Use the <code>one\_hot</code> attribute to prevent priority encoding of the set and reset signals. Presto VHDL generates the verbose inference report shown in Example 4-44.

#### Example 4-43 JK Flip-Flop With Asynchronous Set and Reset

```
library IEEE, synopsys;
use IEEE.std_logic_1164.all;
use synopsys.attributes.all;
entity jk_async_sr is
 port (SET, RESET, J, K, CLK : in std_logic;
        Q_out : out std_logic );
  attribute sync_set_reset of J, K :
    signal is "true";
  attribute one_hot of SET, RESET : signal is "true";
end jk_async_sr;
architecture rtl of jk_async_sr is
  signal Q : std_logic;
begin
process (CLK, SET, RESET)
 variable JK : std_logic_vector (1 downto 0);
begin
  if (RESET = '1') then
    Q <= '0';
  elsif (SET = '1') then
    0 <= '1';
  elsif (CLK'event and CLK = '1') then
    JK := (J \& K);
    case JK is
      when "01" \Rightarrow Q \Leftarrow '0';
      when "10" => Q <= '1';
when "11" => Q <= not(Q);
      when "00" => Q <= Q;
      when others => Q <= 'X';
    end case;
  end if;
end process;
Q_out <= Q;
end rtl;
```

# Example 4-44 Inference Report for a JK Flip-Flop With Asynchronous Set and Reset

| Register Name          | <br>  Type | Width | Bus | =====<br>  MB | ====<br>  AR | =====<br>  AS | =====<br>  SR | =====<br>  SS | =====<br>  ST | =<br> <br> |
|------------------------|------------|-------|-----|---------------|--------------|---------------|---------------|---------------|---------------|------------|
|                        | Flip-flop  | 1     | N N | N             | Y            | Y             | Y             | Y             | N             | _          |
| Sequential Cell (Q_reg | · )        |       |     |               |              |               |               |               |               | -          |

Cell Type: Flip-Flop
Multibit Attribute: N
Clock: CLK
Async Clear: RESET
Async Set: SET
Async Load: 0
Sync Clear: J' K
Sync Set: J K'
Sync Toggle: 0
Sync Load: K

## **Inferring Master-Slave Latches**

This section contains the following subsections:

- Master-Slave Latch Overview
- Master-Slave Latch: Single Master-Slave Clock Pair
- Master-Slave Latch: Multiple Master-Slave Clock Pairs
- Master-Slave Latch: Discrete Components

## **Master-Slave Latch Overview**

Design Compiler infers master-slave latches by using the clocked\_on\_also attribute.

In your VHDL description, describe the master-slave latch as a flip-flop, using only the slave clock. Specify the master clock as an input port, but do not connect it. In addition, set the clocked\_on\_also attribute on the master clock port (called MCK in these examples).

This coding style requires that cells in the target technology library contain slave clocks defined with the clocked\_on\_also attribute. The clocked\_on\_also attribute defines the slave clocks in the cell's state declaration. For more information about defining slave clocks in the target technology library, see the *Library Compiler User Guide*.

If Design Compiler does not find any master-slave latches in the target technology library, the tool leaves the master-slave generic cell (MSGEN) unmapped. Design Compiler does not use D flip-flops to implement the equivalent functionality of the cell.

#### Note:

Although the vendor's component behaves as a master-slave latch, Library Compiler supports only the description of a master-slave flip-flop.

## Master-Slave Latch: Single Master-Slave Clock Pair

Example 4-45 provides the VHDL template for a master-slave latch.

See "dc\_tcl\_script\_begin and dc\_tcl\_script\_end" on page 6-3 for more information on the dc\_tcl\_script\_begin and dc\_tcl\_script\_end compiler directives. Presto VHDL generates the verbose inference report shown in Example 4-46.

#### Example 4-45 Master-Slave Latch

```
library IEEE;
use IEEE.std_Logic_1164.all;
entity mslatch is
 port(MCK, SCK, DATA : in std_logic;
       Q : out std logic );
end mslatch;
architecture rtl of mslatch is
begin
--synopsys dc tcl script begin
--set_attribute -type string MCK signal clocked_on_also
--set_attribute -type boolean MCK level_sensitive true
--synopsys dc_tcl_script_end
process(SCK, DATA) begin
  if (SCK'event and SCK= '1') then
   O <= DATA;
  end if;
end process;
end rtl;
```

## Example 4-46 Inference Report for a Master-Slave Latch

| === | ======================================= |           | =  | ====== | =: | ===== | == | ==== | = | ==== | == | ==== | == | ===: | ==: | ==== | ==: | === |  |
|-----|-----------------------------------------|-----------|----|--------|----|-------|----|------|---|------|----|------|----|------|-----|------|-----|-----|--|
|     | Register Name                           | Type      |    | Width  |    | Bus   |    | MB   |   | AR   |    | AS   |    | SR   |     | SS   |     | ST  |  |
| === | ======================================= | ========  | =  | ====== | =  | ===== | == | ==== | = | ==== | == | ==== | == | ===: | ==: | ==== | ==: | === |  |
|     | Q_reg                                   | Flip-flop |    | 1      |    | N     |    | N    |   | N    |    | N    |    | N    |     | N    |     | N   |  |
| === | ============                            | ========  | == | ====== | =  | ===== | == | ==== | = | ==== | == | ===: | == | ===: | ==  | ===: | ==: | === |  |

## Master-Slave Latch: Multiple Master-Slave Clock Pairs

If the design requires more than one master-slave clock pair, you must specify the associated slave clock in addition to the clocked\_on\_also attribute. Example 4-47 illustrates the use of clocked\_on\_also with the associated\_clock option. Example 4-48 shows the verbose inference reports.

#### Example 4-47 Inferring Master-Slave Latches With Two Pairs of Clocks

```
library IEEE;
use IEEE.std_Logic_1164.all;
entity mslatch2 is
 port(SCK1, MCK1, DATA1, SCK2, MCK2, DATA2 : in std_logic;
 Q1, Q2 : out std_logic );
end mslatch2;
architecture rtl of mslatch2 is
begin
--synopsys dc_tcl_script_begin
--set_attribute -type string MCK1 signal clocked_on_also
--set_attribute -type boolean MCK1 level_sensitive true
--set_attribute -type string MCK1 associated_clock SCK1
--set_attribute -type string MCK2 signal clocked_on_also
--set_attribute -type boolean MCK2 level_sensitive true
--set_attribute -type string MCK2 associated_clock SCK2
--synopsys dc_tcl_script_end
process (SCK1, DATA1) begin
 if (SCK1'event and SCK1 = '1') then
   Q1 <= DATA1;
 end if;
end process;
process (SCK2, DATA2) begin
  if (SCK2'event and SCK2 = '1') then
    Q2 <= DATA2;
 end if:
end process;
end rtl;
```

#### Example 4-48 Inference Reports for Master-Slave Latch: Multiple Clock Pairs

```
Inferred memory devices in process
      in routine mslatch2 line 21 in file
          '../rtl/ch4.ex4.47.master.slave.latch.2clks.vhd'
______
Register Name | Type | Width | Bus | MB | AR | AS | SR | SS | ST |
______
   Q1_reg | Flip-flop | 1 | N | N | N | N | N | N |
______
Inferred memory devices in process
     in routine mslatch2 line 27 in file
           '../rtl/ch4.ex4.47.master.slave.latch.2clks.vhd'
______
Register Name | Type | Width | Bus | MB | AR | AS | SR | SS | ST |
______
  Q2_reg | Flip-flop | 1 | N | N | N | N | N | N | N
______
```

## **Master-Slave Latch: Discrete Components**

If your target technology library does not contain master-slave latch components, you can infer two-phase systems using two D latches. Example 4-49 shows a simple two-phase system with clocks MCK and SCK. Example 4-50 shows the verbose inference reports.

#### Example 4-49 Two-Phase Clocks

```
library IEEE;
use IEEE.std_Logic_1164.all;
entity LATCH VHDL is
  port(MCK, SCK, DATA: in std_logic;
       Q : out std_logic );
end LATCH VHDL;
architecture rtl of LATCH VHDL is
  signal TEMP : std logic;
begin
process (MCK, DATA) begin
  if (MCK = '1') then
    TEMP <= DATA;
  end if;
end process;
process (SCK, TEMP) begin
  if (SCK = '1') then
   O <= TEMP;
  end if;
end process;
end rtl;
```

## Example 4-50 Inference Reports for Two-Phase Clocks

```
Inferred memory devices in process
    in routine LATCH_VHDL line 10 in file
       '/remote/vhdl_example/latch_vhdl.vhd'.
______
Register Name | Type | Width | Bus | MB | AR | AS | SR | SS | ST |
______
  TEMP_reg | Latch | 1 | N | N | N | N | - | - | - |
Inferred memory devices in process
   in routine LATCH_VHDL line 15 in file
       '/remote/vhdl_example/latch_vhdl.vhd'.
______
Register Name | Type | Width | Bus | MB | AR | AS | SR | SS | ST |
______
Q_reg | Latch | 1 | N | N | N | N | - | - | - |
______
```

```
Sequential Cell (TEMP_reg)
Cell Type: Latch
Multibit Attribute: N
Clock: 0
Async Clear: 0
Async Set: 0
Async Load: MCK

Sequential Cell (Q_reg)
Cell Type: Latch
Multibit Attribute: N
Clock: 0
Async Clear: 0
Async Set: 0
Async Load: SCK
```

## **Limitations of Register Inference**

For best results when inferring registers, restrict each process to inferring a single type of memory cell, use the templates provided in this chapter, and understand the following inference limitations.

Presto VHDL cannot infer the following components. You must instantiate them in your VHDL description.

- Flip-flops and latches with three-state outputs
- Flip-flops with bidirectional pins
- Flip-flips with multiple clock inputs
- Multiport latches
- Register banks

Note:

Although you can instantiate flip-flops with bidirectional pins, Design Compiler interprets these cells as black boxes.

If you use an if statement to infer D flip-flops, your design must meet the following requirements:

The edge expression, such as CLK'event rising\_edge (CLK), must be the only condition
of an if or an elsif clause.

The following if statement is invalid, because it has multiple conditions in the if clause:

```
if (edge \text{ and RST} = '1')
```

 You can have only one edge expression in an if clause, and the if clause must not have an else clause.

The following if statement is invalid, because you cannot include an else clause when using an edge expression as the if or elsif condition:

```
if X > 5 then
   sequential_statement;
elsif edge then
   sequential_statement;
else
   sequential_statement;
end if;
```

 An edge expression cannot be part of another logical expression or be used as an argument.

The following function call is invalid, because you cannot use the edge expression as an argument:

```
any_function(edge);
```

• If you are using only wait statements for sequential inferencing, only one wait statement is allowed in a process. Coding styles using multiple wait statements, such as FSMs using multiple wait statements, are not supported. The tool generates the following error message if you use multiple wait statements in a process:

```
Presto does not support processes with multiple event statements. (ELAB-336)
```

## **Unloaded Sequential Cell Preservation**

Presto Verilog does not automatically keep unloaded or undriven flip-flops or latches in a design. These cells are determined to be unnecessary and are removed during optimization. You can use the hdlin\_preserve\_sequential variable to control which cells to preserve:

- To preserve unloaded/undriven flip-flops and latches in your GTECH netlist, set hdlin preserve sequential to all.
- To preserve all unloaded flip-flops only, set hdlin preserve sequential to ff.
- To preserve all unloaded latches only, set hdlin\_preserve\_sequential to latch.
- To preserve all unloaded sequential cells, including unloaded sequential cells that are used solely as loop variables, set hdlin\_preserve\_sequential to all+loop\_variables.
- To preserve flip-flop cells only, including unloaded sequential cells that are used solely as loop variables, set hdlin\_preserve\_sequential to ff+loop\_variables.

• To preserve unloaded latch cells only, including unloaded sequential cells that are used solely as loop variables, set hdlin\_preserve\_sequential to latch+loop\_variables.

Example 4-51 and Example 4-52 indicate which components are saved when hdlin\_preserve\_sequential is set to all (the default is none). For more details about hdlin\_preserve\_sequential, see the man page.

#### **Important:**

To preserve unloaded cells through compile, you also need to set compile\_delete\_unloaded\_sequential\_cells to false (the default is true); otherwise, Design Compiler will optimize them away.

Example 4-51 has hdlin\_preserve\_sequential set to all to save the unloaded cell sum2 and the combinational logic preceding it; note that the combinational logic after it is not saved. If you also want to save the combinational logic after sum2, you need to recode the design as shown in Example 4-52.

## Example 4-51 Preserves an Unloaded Cell (sum2) and Two Adders

```
set hdlin_preserve_sequential = all
library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.std_logic_unsigned.all;
entity seq_cell_ex2 is
  port(
       in1, in2, in3 : in std_logic_vector(1 downto 0);
       out_z : out std_logic_vector(1 downto 0);
       clk
                   : in std_logic);
end seq_cell_ex2;
architecture rtl of seq_cell_ex2 is
  signal sum1, sum2 : std_logic_vector(1 downto 0);
  signal save : std_logic_vector(1 downto 0);
begin
process (clk) begin
  if (clk'event and clk = '1') then
    sum1 <= in1 + in2;</pre>
    sum2 \ll in1 + in2 + in3; -- sum2 reg is saved
  end if;
end process;
out_z <= not sum1;
```

end rtl;

Example 4-52 preserves the sum2 register and all combinational logic before it.

#### Example 4-52 Preserves an Unloaded Cell (save) and Three Adders

```
set hdlin_preserve_sequential = all
library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.std_logic_unsigned.all;
entity seq_cell_ex3 is
 port(
       in1, in2, in3 : in std_logic_vector(1 downto 0);
       out_z : out std_logic_vector(1 downto 0);
                   : in std_logic);
       clk
end seq_cell_ex3;
architecture rtl of seq_cell_ex3 is
signal sum1, sum2 : std_logic_vector(1 downto 0);
signal save : std_logic_vector(1 downto 0);
process (clk) begin
  if (clk'event and clk = '1') then
    sum1 <= in1 + in2;
    sum2 <= in1 + in2 + in3; -- this combinational logic</pre>
                             -- is saved
  end if;
end process;
out_z <= not sum1;
process (clk) begin
  if (clk'event and clk = '1') then
   save <= sum1 + sum2; -- this combinational logic is saved
  end if;
end process;
end rtl;
```

#### Note:

By default, the hdlin\_preserve\_sequential variable does not preserve variables used in for loops as unloaded registers. To preserve these variables, you must set hdlin\_preserve\_sequential to ff+loop\_variables.

#### Note:

The tool does not distinguish between unloaded cells (those not connected to any output port) and feedthroughs. See Example 4-53 for an example of a feedthrough.

## Example 4-53

```
entity reg1 is
  port (
    d0, clk : in bit;
    q0: out bit);
end entity reg1;
architecture behave of reg1 is
begin -- behave
  storage: process (clk)
    variable temp1, temp2 : bit;
        if clk'event and clk = '1' then
          temp1 := d0;
          temp2 := temp1;
        end if;
        q0 \ll temp2;
      end process storage;
end behave:
```

With hdlin\_preserve\_sequential set to ff, Presto VHDL builds two registers: one for the feedthrough cell temp1 and the other for the loaded cell temp2, as shown in the following memory inference report:

## Example 4-54 Feedthrough Register temp1

| ====      | Register Name          | ====================================== | ===<br>  W   | =====<br>idth   |  | ====<br>Bus    | =:  | ====<br>MB     | =   | ====<br>AR     |  | AS     | ==: | SR             | =: | ss             |  | ====<br>ST |  |
|-----------|------------------------|----------------------------------------|--------------|-----------------|--|----------------|-----|----------------|-----|----------------|--|--------|-----|----------------|----|----------------|--|------------|--|
| <br> <br> | temp1_reg<br>temp2_reg | Flip-flop<br>  Flip-flop               | ===<br> <br> | =====<br>1<br>1 |  | ====<br>N<br>N | - ! | ====<br>N<br>N | - ! | ====<br>N<br>N |  | N<br>N | - ! | ====<br>N<br>N |    | ====<br>N<br>N |  | N<br>N     |  |

# 5

# Inferring Three-State Logic

Presto VHDL infers a three-state buffer when you assign the value of Z to a signal or variable. The Z value represents the high-impedance state. Presto VHDL infers one three-state buffer per process. You can assign high-impedance values to single-bit or bused signals (or variables). Presto VHDL does not provide any variables, attributes, or directives to control the inference.

This chapter includes the following sections:

- Inference Report for Three-State Devices
- Inferring a Basic Three-State Driver
- Inferring One Three-State Buffer From a Single Process
- Inferring Two Three-State Buffers
- Three-State Buffer With Registered Enable
- Three-State Buffer With Registered Data
- Understanding the Limitations of Three-State Inference

## Inference Report for Three-State Devices

The hdlin\_reporting\_level variable determines whether Presto VHDL generates a three-state inference report. If you do not want inference reports, set hdlin\_reporting\_level to none. The default is basic, meaning that a report will be generated. Example 5-1 shows a three-state inference report:

## Example 5-1 Three-State Inference Report

The first column of the report indicates the name of the inferred three-state device. The second column indicates the type of inferred device. The third column indicates the width of the inferred device. The fourth column indicates whether the device is multibit.

Presto VHDL generates the same report for the default and verbose reports for three-state inference. For more information about the hdlin\_reporting\_level variable, see "Elaboration Reports" on page 1-7.

## Inferring a Basic Three-State Driver

Example 5-2 provides the VHDL template for a basic three-state buffer. Presto VHDL generates the inference report shown in Example 5-3. Figure 5-1 shows the compiled output.

#### Example 5-2 Basic Three-State Buffer

```
library IEEE, synopsys;
use IEEE.std_logic_1164.all;
entity three_state_basic is
port(IN1, ENABLE : in std_logic;
    OUT1 : out std_logic );
end;

architecture rtl of three_state_basic is
begin

process (IN1, ENABLE) begin
  if (ENABLE = '1') then
   OUT1 <= IN1;
else</pre>
```

```
OUT1 <= 'Z'; -- assigns high-impedance state
end if;
end process;
end rtl;</pre>
```

#### Example 5-3 Inference Report for a Basic Three-State Buffer

| ===========   | :==========      |            |
|---------------|------------------|------------|
| Register Name | Type             | Width   MB |
| OUT1_tri      | Tri-State Buffer | 1   N      |

Figure 5-1 A Basic Three-State Buffer



## Inferring One Three-State Buffer From a Single Process

Example 5-4 provides an example of placing all high-impedance assignments in a single process. In this case, the data is gated and Presto VHDL infers a single three-state buffer. Example 5-5 shows the inference report.

#### Example 5-4 Inferring One Three-State Buffer From a Single Process

```
T <= B;
end if;
end process infer;
end rtl;
```

#### Example 5-5 Single Process Inference Report

| Register Name | <br>  Type       | =======<br>  Width | MB |
|---------------|------------------|--------------------|----|
| T_tri         | Tri-State Buffer | 1                  | N  |

## **Inferring Two Three-State Buffers**

Example 5-6 provides an example of placing each high-impedance assignment in a separate process. In this case, Presto VHDL infers multiple three-state buffers. Example 5-7 shows the inference report. Figure 5-2 shows the design.

#### Example 5-6 Inferring Two Three-State Buffers

```
library IEEE;
use IEEE.std_logic_1164.all;
entity three state is
 port ( A, B, SELA, SELB : in std_logic ;
         T : out std_logic );
end three_state;
architecture rtl of three_state is
infer1 : process (SELA, A) begin
  if (SELA = '1') then
    T \ll A;
  else
    T \ll Z';
  end if;
end process infer1;
infer2 : process (SELB, B) begin
  if (SELB = '1') then
   T \ll B;
  else
   T <= 'Z';
  end if;
end process infer2;
end rtl;
```

Example 5-7 Inference Report for Two Three-State Buffers

|   | Register | Name | ====================================== |   | ======<br>Width |   | ====<br>MB | = |
|---|----------|------|----------------------------------------|---|-----------------|---|------------|---|
|   | T_tri    |      | Tri-State Buffer                       |   | 1<br>1          |   | N          |   |
|   |          |      |                                        |   |                 |   |            | _ |
| Ī | Register | Name | Type                                   | Ī | Width           | Ī | MB         | _ |
| Ī | T_tri2   |      | Tri-State Buffer                       |   | 1               |   | N          |   |

Figure 5-2 Two Three-State Buffers



## **Three-State Buffer With Registered Enable**

When a variable, such as THREE\_STATE in Example 5-8, is assigned to a register and defined as a three-state buffer within the same process, Presto VHDL also registers the enable pin of the three-state gate. Example 5-8 shows an example of this type of code, and Example 5-9 shows the inference report. Figure 5-3 shows the schematic generated by the code, a three-state buffer with a register on its enable pin.

#### Example 5-8 Inferring a Three-State Buffer With Registered Enable

```
library IEEE;
use IEEE.std logic 1164.all;
entity three_state is
   port ( DATA, CLK, THREE_STATE : in std_logic ;
          OUT1 : out std_logic );
end three_state;
architecture rtl of three_state is
begin
infer: process (THREE STATE, CLK) begin
   if (THREE\_STATE = '0') then
      OUT1 <= 'Z';
   elsif (CLK'event and CLK = '1') then
      OUT1 <= DATA;
   end if;
end process infer;
end rtl;
```

#### Example 5-9 Inference Report for a Three-State Buffer With Registered Enable



Figure 5-3 Three-State Buffer With Registered Enable

## **Three-State Buffer With Registered Data**

Example 5-10 uses two processes to instantiate a three-state buffer, with a flip-flop on the input pin. Example 5-11 shows the inference report. Figure 5-4 shows the schematic generated by the code.

#### Example 5-10 Three-State Buffer With Registered Data

```
library IEEE;
use IEEE.std_logic_1164.all;
entity ff_3state2 is
    port ( DATA, CLK, THREE_STATE : in std_logic ;
        OUT1 : out std_logic );
end ff_3state2;
architecture rtl of ff_3state2 is
    signal TEMP : std_logic;
begin

process (CLK) begin
    if (CLK'event and CLK = '1') then
```

```
TEMP <= DATA;
end if;
end process;

process (THREE_STATE, TEMP) begin
  if (THREE_STATE = '0') then
    OUT1 <= 'Z';
  else
    OUT1 <= TEMP;
  end if;
end process;
end rtl;</pre>
```

Example 5-11 Inference Report for a Three-State Buffer With Registered Data

| Register Name                          | ========<br>  Type                     | =====<br>  Widt         | ===:<br>n      | Bus          |                      | MB                |                | AR                |                | as<br>AS          |                 | SR                |                | SS                |
|----------------------------------------|----------------------------------------|-------------------------|----------------|--------------|----------------------|-------------------|----------------|-------------------|----------------|-------------------|-----------------|-------------------|----------------|-------------------|
| TEMP_reg<br>  N                        | ====================================== | ======<br>  1<br>====== | <br> <br> <br> | N<br>=====   | ===<br> <br> <br>=== | ====<br>N<br>==== | <br> <br> <br> | ====<br>N<br>==== | -=:<br> <br> : | ====<br>N<br>==== | -=:<br> <br> -: | ====<br>N<br>==== | ==:<br> <br> : | ====<br>N<br>==== |
| ====================================== | =======<br>Type                        | =====<br>  Wid          | ===:<br>:h     | ====<br>  MB | ==                   |                   |                |                   |                |                   |                 |                   |                |                   |
| OUT1_tri   Tri-                        | state Buffer                           | 1<br>  1                |                | ====<br>  N  |                      |                   |                |                   |                |                   |                 |                   |                |                   |

Figure 5-4 Three-State Buffer With Registered Data



## **Understanding the Limitations of Three-State Inference**

You can use the Z value as

- · A signal assignment
- A variable assignment
- · A function call argument
- · A return value
- An aggregate definition

You cannot use the z value in an expression, except for concatenation and comparison with z, such as in

```
if (IN_VAL = 'Z') then y<=0 endif;
```

This is an example of permissible use of the  ${\tt z}$  value in an expression, but it always evaluates to false. So it is also a simulation/synthesis mismatch.

#### This code

```
OUT_VAL <= ('Z' and IN_VAL);
```

is an example of an incorrect use of the z value in an expression. It is incorrect because it is not a comparison expression. This code generates an error because Presto VHDL cannot compute any expressions that use 'Z' as an input.

Be careful when using expressions that compare with the z value. Design Compiler always evaluates these expressions to false, and the pre-synthesis and post-synthesis simulation results might differ. For this reason, Presto VHDL issues a warning when it synthesizes such comparisons.

# 6

## Directives, Attributes, and Variables

This chapter describes the directives, attributes, and HDL read variables supported by Presto VHDL in the following sections:

- Directives
- Attributes
- Variables

#### **Directives**

Presto VHDL directives are special comments that affect the actions of the Synopsys Presto VHDL and Design Compiler. These comments are ignored by other VHDL tools. They begin with two hyphens (--) and are followed by pragma or synopsys.

#### Note:

Presto VHDL displays a syntax error if an unrecognized directive is encountered after --synopsys or --pragma.

This section describes the following directives:

- keep\_signal\_name
- template
- translate\_off and translate\_on
- synthesis off and synthesis on
- resolution method
- map\_to\_entity and return\_port\_name
- dc\_tcl\_script\_begin and dc\_tcl\_script\_end

## keep\_signal\_name

You can give Presto VHDL guideline information for keeping a signal name by using the hdlin\_keep\_signal\_name variable (default is all\_driving) and the keep\_signal\_name directive. For details, see "Keeping Signal Names" on page 2-31.

## template

The template directive is used to read a design with a generic given that the generic default is specified. See "Parameterized Models (Generics)" on page 1-17.

## translate off and translate on

The code contained within these directives is ignored and treated as comments.

## synthesis\_off and synthesis\_on

The code contained within these directives is ignored and treated as comments.

#### resolution\_method

Resolution directives determine the resolution function associated with resolved signals. Presto VHDL does not support arbitrary resolution functions. It only supports the following three resolution methods:

```
-- synopsys resolution_method wired_and
-- synopsys resolution_method wired_or
-- synopsys resolution_method three_state
```

For more details, see "Resolution Functions" on page 2-33.

### map to entity and return port name

Component implication directives map VHDL subprograms onto existing components or VHDL entities.

Synopsys supports the following component implication directives:

```
-- synopsys map_to_entity entity_name
-- synopsys return_port_name port_name
```

See "Procedures and Functions as Design Components" on page 2-8. Other directives, such as map\_to\_operator, are used to drive inference of HDL operators such as \*, +, and -. See the *DesignWare Developer Guide* for more information about synthetic comments.

## dc\_tcl\_script\_begin and dc\_tcl\_script\_end

You can embed Tcl commands that set design constraints and attributes within the RTL by using the dc\_tcl\_script\_begin and dc\_tcl\_script\_end directives, as shown in Example 6-1.

#### Example 6-1

```
-- synopsys dc_tcl_script_begin
-- set_max_area 0.0
-- set_drive -rise 1 port_b
-- set_max_delay 0.0 port_z
-- synopsys dc_tcl_script_end
...
```

Design Compiler interprets the statements embedded between the  $dc\_tcl\_script\_begin$  and the  $dc\_tcl\_script\_end$  directives. If you want to comment out part of your script, use the # comment character.

The following items are not supported in embedded Tcl scripts:

- Hierarchical constraints
- Wildcards
- List commands
- Multiple-line commands

Following are guidelines for using embedded Tcl scripts:

- You cannot embed Tcl scripts outside an entity or architecture; they must be embedded inside an entity or architecture.
- Constraints and attributes declared inside an entity or architecture apply only to the enclosing entity or architecture.
- Any dc shell scripts embedded in functions apply to the whole module.
- Include only commands that set constraints and attributes. Do not use action commands such as compile, gen, and report. The tool ignores these commands and issues a warning or error.
- The constraints or attributes set in the embedded script go into effect after the read command is executed. Therefore, variables that affect the read process itself are not in effect before the read. For example, if you set the hdlin\_no\_latches variable to true in the embedded script, this variable does not influence latch inference in the current read.
- Design Compiler performs error checking after the read command finishes. Syntactic and semantic errors in dc\_shell strings are reported at this time.
- You can have more than one dc\_tcl\_script\_begin / dc\_tcl\_script\_end pair per file or entity/architecture. The compiler does not issue an error or warning when it sees more than one pair. Each pair is evaluated and set on the applicable code.
- An embedded dc\_shell script does not produce any information or status messages unless there is an error in the script.
- If you use embedded Tcl scripts while running in dcsh mode, Design Compiler issues the following error message:

```
Error: Design 'MID' has embedded Tcl commands which are ignored in EQN mode. (UIO-162) \,
```

- Usage of built-in Tcl commands is not recommended.
- Usage of output redirection commands is not recommended.

## **Attributes**

This section describes the following:

- Synopsys Defined Attributes
- IEEE Predefined Attributes

## **Synopsys Defined Attributes**

The Synopsys defined attributes are listed in Table 6-1. When you use these attributes, insert the following line in your VHDL description, just before the entity declaration.

```
use SYNOPSYS.ATTRIBUTES.all;
```

These attributes are included in the ATTRIBUTES package.

Table 6-1 Attributes Supported by Presto VHDL

| Attribute                 | Description                                    |
|---------------------------|------------------------------------------------|
| arrival                   | See Table 6-2 on page 6-7.                     |
| async_set_reset           | See Table 4-2 on page 4-6.                     |
| async_set_reset_local     | See Table 4-2 on page 4-6.                     |
| async_set_reset_local_all | See Table 4-2 on page 4-6.                     |
| dont_touch                | See Table 6-2 on page 6-7.                     |
| dont_touch_network        | See Table 6-2 on page 6-7.                     |
| drive_strength            | See Table 6-2 on page 6-7.                     |
| enum_encoding             | See "Synopsys Defined Attributes" on page 6-5. |
| equal                     | See Table 6-2 on page 6-7.                     |
| fall_arrival              | See Table 6-2 on page 6-7.                     |
| fall_drive                | See Table 6-2 on page 6-7.                     |
| infer_multibit            | See "Multibit Inference" on page 2-40.         |
| infer_mux                 | See "MUX_OP Inference" on page 3-10.           |

Table 6-1 Attributes Supported by Presto VHDL (Continued)

| Attribute                | Description                                           |
|--------------------------|-------------------------------------------------------|
| load                     | See Table 6-2 on page 6-7.                            |
| logic_one                | See Table 6-2 on page 6-7.                            |
| logic_zero               | See Table 6-2 on page 6-7.                            |
| map_to_module            | See "map_to_entity and return_port_name" on page 6-3. |
| max_area                 | See Table 6-2 on page 6-7.                            |
| max_delay                | See Table 6-2 on page 6-7.                            |
| max_fall_delay           | See Table 6-2 on page 6-7.                            |
| max_rise_delay           | See Table 6-2 on page 6-7.                            |
| max_transition           | See Table 6-2 on page 6-7.                            |
| min_delay                | See Table 6-2 on page 6-7.                            |
| min_fall_delay           | See Table 6-2 on page 6-7.                            |
| min_rise_delay           | See Table 6-2 on page 6-7.                            |
| one_cold                 | See Table 4-2 on page 4-6.                            |
| one_hot                  | See Table 4-2 on page 4-6.                            |
| opposite                 | See Table 6-2 on page 6-7.                            |
| rise_arrival             | See Table 6-2 on page 6-7.                            |
| rise_drive               | See Table 6-2 on page 6-7.                            |
| sync_set_reset           | See Table 4-2 on page 4-6.                            |
| sync_set_reset_local     | See Table 4-2 on page 4-6.                            |
| sync_set_reset_local_all | See Table 4-2 on page 4-6.                            |
| unconnected              | See "Synopsys Defined Attributes" on page 6-5.        |

The design attributes are described in Table 6-2.

Table 6-2 Design Attributes

| Attribute             | Туре    | Description                                                                                                          |
|-----------------------|---------|----------------------------------------------------------------------------------------------------------------------|
| Input port Attributes |         |                                                                                                                      |
| MAX_AREA              | real    | Maximum desired area, in technology library                                                                          |
|                       |         | area units. attribute MAX_AREA of EXAMPLE : entity is 500.0;                                                         |
| MAX_TRANSITION        | real    | Maximum allowable transition time for any                                                                            |
|                       |         | network in the design, in technology library                                                                         |
|                       |         | time units.<br>attribute MAX_TRANSITION of EXAMPLE : entity is 3.0;                                                  |
| ARRIVAL               | real    | Expected signal arrival time, in technology                                                                          |
|                       |         | library time units. Sets both RISE_ARRIVAL and                                                                       |
|                       |         | FALL_ARRIVAL. attribute ARRIVAL of A : signal is 1.5;                                                                |
|                       |         | attribute Artifivate of A. Signal is 1.3,                                                                            |
| DRIVE_STRENGTH        | real    | Input signal's drive strength, in technology                                                                         |
|                       |         | library load units. Sets both RISE_DRIVE and FALL_DRIVE.                                                             |
|                       |         | attribute DRIVE_STRENGTH of A, B : signal is 0.01;                                                                   |
| RISE_ARRIVAL          | real    | Input signal's rise time.                                                                                            |
| NISE_ANNIVAL          | rear    | attribute RISE_ARRIVAL of C : signal is 1.5;                                                                         |
| EALL ADDIVAL          | rool    | -                                                                                                                    |
| FALL_ARRIVAL          | real    | Input signal's fall time. attribute FALL_ARRIVAL of A, B : signal is 1.5;                                            |
| EALL DDW/E            |         | •                                                                                                                    |
| FALL_DRIVE            | real    | <ul> <li>Input signal's drive strength while falling.</li> <li>attribute FALL_DRIVE of B: signal is 0.01;</li> </ul> |
|                       |         | •                                                                                                                    |
| RISE_DRIVE            | real    | Input signal's drive strength while rising.                                                                          |
|                       |         | attribute RISE_DRIVE of A : signal is 0.01;                                                                          |
| EQUAL                 | boolean | Applied to pairs of input ports; true                                                                                |
|                       |         | if both ports are logically equal. attribute EQUAL of A, B : signal is TRUE;                                         |
|                       |         | The attributes EQUAL and OPPOSITE are used only for pairs                                                            |
|                       |         | of single-bit ports (signals).                                                                                       |

Table 6-2 Design Attributes (Continued)

| Attribute              | Туре    | Description                                                                                                                                                                                                |
|------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OPPOSITE               | boolean | Applied to pairs of input ports; true if the two ports are logically opposite. attribute OPPOSITE of A, B: signal is TRUE;                                                                                 |
| LOGIC_ONE              | boolean | True if the input port is always at logic one. attribute LOGIC_ONE of A : signal is TRUE;                                                                                                                  |
| LOGIC_ZERO             | boolean | True if the input port is always at logic zero attribute LOGIC_ZERO of A, B: signal is TRUE;                                                                                                               |
| DONT_TOUCH_NETWO<br>RK | boolean | True if the network connected to the input port is to be excluded from optimization attribute DONT_TOUCH_NETWORK of A : signal is TRUE;                                                                    |
| Output Port Attributes |         |                                                                                                                                                                                                            |
| LOAD                   | real    | Loading on output port, in library load units.<br>attribute LOAD of Y, Z : signal is 5.0;                                                                                                                  |
| UNCONNECTED            | boolean | May be set to true if the output port is not connected to external circuitry. attribute UNCONNECTED of X : signal is TRUE;                                                                                 |
| MIN_RISE_DELAY         | real    | Minimum allowable delay time before the output port's signal rises.attribute MIN_RISE_DELAY of X : signal is 5.0;                                                                                          |
| MIN_FALL_DELAY         | real    | Minimum allowable delay time before the output port's signal falls. attribute MIN_FALL_DELAY of Y: signal is 5.0;                                                                                          |
| MAX_DELAY              | real    | Maximum allowable delay time, from any input signal connected to the output port, in technology library time units Sets both MAX_RISE_DELAY and MAX_FALL_DELAY. attribute MAX_DELAY of X : signal is 20.0; |

Table 6-2 Design Attributes (Continued)

| Attribute       | Туре    | Description                                                                                                                                   |
|-----------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| MAX_RISE_DELAY  | real    | Maximum allowable delay time before                                                                                                           |
|                 |         | the output port's signal rises.                                                                                                               |
|                 |         | attribute MAX_RISE_DELAY of Z : signal is 20.0;                                                                                               |
| MAX_FALL_DELAY  | real    | Maximum allowable delay time before                                                                                                           |
|                 |         | the output port's signal falls.                                                                                                               |
|                 |         | attribute MAX_FALL_DELAY of X, Y : signal is 20.0;                                                                                            |
| MIN_DELAY       | real    | Minimum allowable delay time, from any                                                                                                        |
|                 |         | input signal connected to the output                                                                                                          |
|                 |         | port, in technology library time units.                                                                                                       |
|                 |         | Sets both MIN_RISE_DELAY and MIN_FALL_DELAY                                                                                                   |
|                 |         | attribute MIN_DELAY of X, Z : signal is 5.0;                                                                                                  |
| Cell attributes |         |                                                                                                                                               |
| DONT_TOUCH      | boolean | True if the instance is not to be optimized. attribute DONT_TOUCH of INSTANCE : label is TRUE; A dont_touch attribute cannot be set to false. |

#### **ENUM\_ENCODING Attribute**

You can override the automatic enumeration encodings and specify your own enumeration encodings with the <code>ENUM\_ENCODING</code> attribute. This interpretation is specific to Presto VHDL. This attribute allows Presto VHDL to interpret your logic correctly. Place the synthesis attribute <code>ENUM\_ENCODING</code> on your primary logic type.

The ENUM\_ENCODING attribute must be a string containing a series of vectors, one for each enumeration literal in the associated type. The encoding vector is specified by '0's, '1's, 'D's, 'U's, and 'Z's, separated by blank spaces.

The possible encoding values for the ENUM\_ENCODING attribute are '0', '1', 'D', 'U', and 'Z' and are described in Table 6-3.

Table 6-3 Encoding Values for the ENUM\_ENCODING Attribute

| Encoding value | Description    |
|----------------|----------------|
| '0'            | Bit value '0'. |
| '1'            | Bit value '1'. |

Table 6-3 Encoding Values for the ENUM\_ENCODING Attribute (Continued)

| Encoding value | Description                                                                                                                                                                                                                                                            |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 'D'            | Don't care (can be either '0' or '1'). To use don't care information, see "Don't Care Inference" on page 9-35.                                                                                                                                                         |
| 'U'            | Unknown. If 'U' appears in the encoding vector for an enumeration, you cannot use that enumeration literal except as an operand to the = and /= operators. You can read an enumeration literal encoded with a 'U' from a variable or signal, but you cannot assign it. |
|                | For synthesis, the = operator returns false and /= returns true when either of the operands is an enumeration literal whose encoding contains 'U'.                                                                                                                     |
| 'Z'            | High impedance. See "Three-State Inference" on page 6-2 for more information.                                                                                                                                                                                          |

The first vector in the attribute string specifies the encoding for the first enumeration literal, the second vector specifies the encoding for the second enumeration literal, and so on. The <code>ENUM\_ENCODING</code> attribute must immediately follow the type declaration.

Example 6-2 illustrates how the default encodings from Example 2-21 on page 2-18 can be changed with the <code>ENUM\_ENCODING</code> attribute.

#### Example 6-2 Using the ENUM ENCODING Attribute

```
attribute ENUM_ENCODING: STRING;
  -- Attribute definition

type COLOR is (RED, GREEN, YELLOW, BLUE, VIOLET);
attribute ENUM_ENCODING of
  COLOR: type is "010 000 011 100 001";
  -- Attribute declaration
```

#### The enumeration values are encoded as follows:

```
RED = "010"

GREEN = "000"

YELLOW = "011"

BLUE = "100"

VIOLET = "001"
```

The result is GREEN < VIOLET < RED < YELLOW < BLUE.

#### Note:

The interpretation of the ENUM\_ENCODING attribute is specific to Presto VHDL. Other VHDL tools, such as simulators, use the standard encoding (ordering).

## **IEEE Predefined Attributes**

See "Names" on page C-6 for the IEEE predefined attributes supported by Presto VHDL.

## **Variables**

Presto VHDL read variables are described in Table 6-4.

Table 6-4 Variables

| Name                               | Default     | Description                                                                                                                                                                                                                                                                      |
|------------------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hdlin_elab_errors_deep             | false       | Allows the elaboration of submodules even if the top-level module elaboration fails, enabling Presto to report more elaboration, link, and VER-37 errors and warnings in a hierarchical design during the first elaboration run. See "Reporting Elaboration Errors" on page 1-8. |
| hdlin_enable_configurations        | False       | Enables configuration support.                                                                                                                                                                                                                                                   |
| hdlin_generate_separator_style     | -           | Specifies the separator string for instances generated in multiple-nested loops. This is a VHDL only supported variable. Verilog generate naming follows the Verilog LRM standard, so this variable is not required.                                                             |
| hdlin_infer_enumerated_types       | False       | Infers enumerated types.                                                                                                                                                                                                                                                         |
| hdlin_infer_function_local_latches | False       | Allows latches to be inferred for functionand procedure-scope variables.                                                                                                                                                                                                         |
| hdlin_keep_signal_name             | all_driving | Attempts to keep a signal name if there is path from the signal to an output port. This includes preserving cells between the signal and the output port.                                                                                                                        |
| hdlin_mux_oversize_ratio           | 100         | Defined as the ratio of the number of MUX inputs to the unique number of data inputs. When this ratio is exceeded, a MUX will not be inferred and the circuit will be generated with SELECT_OPs.                                                                                 |
| hdlin_mux_size_min                 | 2           | Sets the minimum number of data inputs for MUX inference.                                                                                                                                                                                                                        |

Table 6-4 Variables (Continued)

| Name                            | Default | Description                                                                                                                                                                                                                                                                                |
|---------------------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hdlin_mux_size_only             | 1       | Controls which MUX_OP cells receive the size_only attribute. By default, MUX_OP cells that are generated with the RTL infer_mux pragma and that are on set/reset signals receive the size_only attribute. For more information and a complete list of options, see Table 3-3 on page 3-12. |
| hdlin_no_sequential_mapping     | False   | Prevents sequential mapping.                                                                                                                                                                                                                                                               |
| hdlin_one_hot_one_cold_on       | True    | Optimizes according to one_hot and one_cold attributes.                                                                                                                                                                                                                                    |
| hdlin_optimize_array_references | True    | Optimizes constant offsets in array references.                                                                                                                                                                                                                                            |
| hdlin_optimize_enum_types       | False   | Simplifies comparisons based on enumerated type information.                                                                                                                                                                                                                               |

Table 6-4 Variables (Continued)

| Name                                   | Default | Description                                                                                                                                                                                            |
|----------------------------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hdlin_preserve_sequential              | none    | Preserves unloaded sequential cells (latches or flip-flops) that would otherwise be removed during optimization by Presto Verilog. The following options are supported:                                |
|                                        |         | <ul> <li>none or false-No unloaded sequential<br/>cells are preserved. This is the default<br/>behavior.</li> </ul>                                                                                    |
|                                        |         | <ul> <li>all or true—All unloaded sequential<br/>cells are preserved, excluding unloaded<br/>sequential cells that are used solely as<br/>loop variables.</li> </ul>                                   |
|                                        |         | <ul> <li>all+loop_variables or<br/>true+loop_variables—All unloaded<br/>sequential cells are preserved, including<br/>unloaded sequential cells that are used<br/>solely as loop variables.</li> </ul> |
|                                        |         | <ul> <li>ff-Only flip-flop cells are preserved,<br/>excluding unloaded sequential cells that<br/>are used solely as loop variables.</li> </ul>                                                         |
|                                        |         | <ul> <li>ff+loop_variables—Only flip-flop cells<br/>are preserved, including unloaded<br/>sequential cells that are used solely as<br/>loop variables.</li> </ul>                                      |
|                                        |         | <ul> <li>latch—Only unloaded latch cells are<br/>preserved, excluding unloaded<br/>sequential cells that are used solely as<br/>loop variables.</li> </ul>                                             |
|                                        |         | <ul> <li>latch+loop_variables—Only unloaded<br/>latch cells are preserved, including<br/>unloaded sequential cells that are used<br/>solely as loop variables.</li> </ul>                              |
|                                        |         | Important: To preserve unloaded cells through compile, you must set compile_delete_unloaded_sequential_cells to false.                                                                                 |
|                                        |         | See "Unloaded Sequential Cell<br>Preservation" on page 4-37.                                                                                                                                           |
| hdlin_prohibit_nontri_multiple_drivers | True    | Issues an error when a non-tri net is driven by more than one process or continuous assignment.                                                                                                        |

Table 6-4 Variables (Continued)

| Name                              | Default | Description                                                                                                                                                                                                            |
|-----------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hdlin_support_subprogram_var_init | True    | Controls whether or not Presto VHDL honors the initial value given to a variable. When this variable is set to false, the default, Presto VHDL issues a warning that the initial value given to a variable is ignored. |
| hdlin_vhdl_87                     | False   | When true, directs Presto VHDL to use the VHDL-87 standard.                                                                                                                                                            |

# 7

## Write Out Designs in VHDL Format

While using Design Compiler, you can write out any design in a variety of formats, including VHDL. Existing gate-level netlists, sets of logic equations, or technology-specific circuits can be automatically converted to a VHDL description. The resulting VHDL description can serve as documentation of the original design, and you can use it as a starting point for reimplementation in a new technology. In addition, you can give the VHDL description to a VHDL simulator to provide circuit timing information.

The following sections discuss how to write out designs in VHDL format.

- Netlist Writer Variables
- Writing Out VHDL Files
- VHDL Write Variables
- Bit and Bit-Vector Variables
- Resolution Function Variables
- Types and Type Conversion Variables
- Architecture and Configuration Variables
- Preserving Port Types
- VHDL Netlister Coding Considerations

#### **Netlist Writer Variables**

The netlist writer variables discussed in this chapter are listed in Table 7-1.

Table 7-1 Variable Summary

| Group                                    | Attributes/Directives/Variables                                                                                                                                                                                                                                                                       |
|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Write variables                          | <pre>vhdlout_dont_create_dummy_nets, vhdlout_equations, vhdlout_follow_vector_direction, vhdlout_separate_scan_in vhdlout_local_attributes, vhdlout_upcase, vhdlout_use_packages, vhdl, out_write_architecture, vhdlout_write_components, vhdlout_write_entity, vhdlout_write_top_configuration</pre> |
| Bit and bit-vector variables             | <pre>vhdlout_three_state_name, vhdlout_unknown_name, vhdlout_zero_name, vhdlout_bit_type, vhdlout_bit_vector_type, vhdlout_one_name</pre>                                                                                                                                                             |
| Resolution function variables            | <pre>vhdlout_three_state_res_func, vhdlout_wired_and_res_func, vhdlout_wired_or_res_func</pre>                                                                                                                                                                                                        |
| Types and type conversion variables      | <pre>vhdlout_package_naming_style, vhdlout_preserve_hierarchical_types, vhdlout_single_bit</pre>                                                                                                                                                                                                      |
| Architecture and configuration variables | <pre>vhdlout_top_configuration_arch_name, vhdlout_top_configuration_entity_name, vhdlout_top_configuration_name</pre>                                                                                                                                                                                 |

## **Writing Out VHDL Files**

To write out VHDL design files, use the write command.

```
dc_shell> write -format vhdl -output my_file.vhdl
```

The write -format vhdl command is valid whether or not the current design originated as a VHDL source file. You can write out any design, regardless of initial format (equation, netlist, and so on), as a VHDL design.

For more information about the write command, see the *Design Compiler Command-line Interface Guide*.

#### **VHDL Write Variables**

Several dc\_shell variables affect how designs are written out as VHDL files. These variables must be set before you write out the design. They can be set interactively or in your .synopsys\_dc.setup file.

The variables described below affect writing out VHDL (vhdlout\_variables). To list them, enter

```
dc_shell> man vhdlio_variables
vhdlout dont create dummy nets
```

Controls whether the VHDL writer creates dummy nets for connecting unused pins or ports.

By default, this variable is set to false and the VHDL writer creates dummy nets.

Set this variable to true to disable dummy net creation.

```
vhdlout_equations
```

When set to true, this variable determines that combinational logic is written with technology-independent Boolean equations, sequential logic is written with technology-independent wait and if statements, and three-state drivers are written with technology-independent code.

By default, this variable is set to false and all mapped logic is written with technology-specific netlists.

Set this variable to true to force the VHDL writer to write technology-independent logic.

```
vhdlout follow vector direction
```

Controls how the VHDL writer determines the array range direction.

By default, this variable is false and the VHDL writer uses ascending array range values, regardless of the original array range direction.

Set this variable to true to force the VHDL writer to determine the array range direction from the original design.

```
vhdlout_local_attributes
```

This variable is obsolete. Use the write\_script command instead (see the write\_script man page).

```
vhdlout_separate_scan_in
```

Controls how the scan chain is written out in VHDL.

By default, this variable is false and the VHDL writer writes the scan chain in the same file as the design. In this case, the scan chain is not visible in the testbench and parallel-load simulation is not possible.

Set this variable to true to force the VHDL writer to write the scan chain as a separate package to enable parallel-load simulation.

```
vhdlout_upcase
```

Determines, when set to true, that identifiers are written out in uppercase to the VHDL file.

When this variable is set to false, identifiers are written out with their Design Compiler names. The default is false.

```
vhdlout_use_packages
```

This variable is a list of package names. A use clause is written into the VHDL file for each of these packages for all entities; library clauses are also written out as needed.

If this variable is not set or is set to an empty list ({ }), it has no effect on the write command.

To use packages from specific libraries, you can prefix the library to the package name. For example,

#### becomes

```
use IEEE.std_logic_1164.all;
use IEEE.std_logic_arith.all;
use VENDOR.PARTS.FFD;
```

When this variable is set to true (the default), an architecture definition is written out to the VHDL file.

```
vhdlout write components
```

This variable controls whether component declarations for cells mapped to a technology library are written out (if set to true) or not (false).

Component declarations are required by VHDL. If you set this variable to false, make sure a package containing the necessary component declarations is listed in vhdlout\_use\_packages.

The default is true. See also the vhdlout\_use\_packages variable.

```
vhdlout_write_entity
```

When this variable is set to true (the default), an entity definition is written out to the VHDL file and to any conversion packages as necessary.

```
vhdlout_write_top_configuration
```

When this variable is set to true, a top-level configuration definition is written out to the VHDL file.

The default is false.

#### **Bit and Bit-Vector Variables**

Bit and bit-vector variables, whose descriptions follow, define the names of bits, bit vectors, and the associated types.

```
vhdlout_bit_type
```

The name of the bit type used for writing out single-bit values, used with the following variables:

```
vhdlout_one_name
vhdlout_three_state_name
vhdlout_zero_name
vhdlout_bit_vector_type
```

The default is std\_logic. For example, a simulator uses a bit type of t\_logic, defined as

```
type t_logic is (U, D, Z, ..., F0, F1, ...); and a bit vector type of t_logic_vector, defined as
```

```
type t_logic_vector is array (integer range <>) of
t_logic;
```

The following dc\_shell commands define the appropriate bit and bit vector types and values to write.

When writing a generic three-state model, Design Compiler displays an error if vhdlout\_bit\_type is set to its default value of a bit. Set vhdlout\_bit\_type to a bit type that includes a high-impedance value ('Z'). For more information about inferred three-state devices, see Chapter 5, "Inferring Three-State Logic."

```
vhdlout_bit_vector_type
```

The name of the bit vector type used for writing multiple-bit values, used with the vhdlout\_bit\_type, vhdlout\_one\_name, and vhdlout\_zero\_name variables.

The default is std\_logic\_vector. For an example, see the description of vhdlout\_bit\_type.

```
vhdlout one name
```

The name of the enumeration literal that represents a logic 1.

The default is '1'. For an example, see the description of vhdlout\_bit\_type.

```
vhdlout_three_state_name
```

The name of the high-impedance bit value used for three-state device values.

The default is 'Z'.

```
vhdlout unknown name
```

The value used to drive a signal to the unknown state, usually a character literal or an enumeration name.

The default is 'X'.

```
vhdlout_zero_name
```

The name of the enumeration literal that represents a logic 0.

The default is '0'. For an example, see the description of vhdlout\_bit\_type.

#### **Resolution Function Variables**

The resolution function variables, whose descriptions follow, name resolution functions that are written out.

```
vhdlout_three_state_res_func
```

Names a three-state resolution function to use instead of the default function. You must supply this function in a package listed in vhdlout\_use\_packages.

If the variable is set to " " (the default), a resolution function is written out if needed.

```
vhdlout wired and res func
```

Names a wired AND resolution function to use instead of the default function. You must supply this function in a package listed in <a href="https://www.nbc.nuse.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.google.go

If the variable is set to " " (the default), a resolution function is written out if needed.

```
vhdlout_wired_or_res_func
```

Names a wired OR resolution function to use instead of the default. You must supply this function in a package listed in vhdlout\_use\_packages.

If the variable is set to " " (the default), a resolution function is written out if needed.

## **Types and Type Conversion Variables**

The following types and type conversion variables define type conversion functions and how the VHDL writer writes out types.

```
vhdlout_package_naming_style
```

This variable controls how packages of conversion functions are named. The default value is "CONV\_PACK\_%d", where %d is a number that is incremented as necessary to produce a unique name. By default, the package name and the number are separated by underscores ( ).

```
vhdlout_preserve_hierarchical_types
```

This variable affects how ports on lower-level designs are written out. Top-level design ports are controlled by <code>vhdlout\_single\_bit</code>. (A design is considered lower-level if it is instantiated by any of the designs being written out.)

When this variable is set to USER, all ports on lower-level designs are written with their original data types. This option affects only designs that are read in VHDL format.

When set to VECTOR, all ports on lower-level designs are written with their ports bused; ports keep their names. These bused ports contrast to ports that are bit-blasted. Bit-blasting is the term for breaking down a bus to its individual bus members. The port types are defined by <code>vhdlout\_bit\_vector\_type</code> or by <code>vhdlout\_bit\_type</code>, in the case of single-bit ports. This setting is likely to give the most efficient description for simulation. The default is VECTOR. You must ensure that <code>vhdlout\_bit\_vector\_type</code> is an array type whose elements are of <code>vhdlout\_bit\_type</code>.

When this variable is set to BIT, typed ports are bit-blasted. If the type of a port is N bits wide, it is written to the VHDL file as N separate ports. Each port is given the type defined by <code>vhdlout\_bit\_type</code>. This variable has no effect if you set <code>vhdlout\_single\_bit to BIT</code>. <code>vhdlout\_preserve\_hierarchical\_types</code> is then ignored, and the whole design hierarchy is written out bit-blasted.

This variable cannot take on a higher value than the current setting of vhdlout\_single\_bit. The descending order is {USER, VECTOR, BIT}. Thus, the combination of vhdlout\_single\_bit set to VECTOR and vhdlout\_preserve\_hierarchical\_types set to USER is not possible.

```
vhdlout_single_bit
```

This variable affects how ports on the top-level design are written out. Lower-level design ports are controlled by <code>vhdlout\_preserve\_hierarchical\_types</code>. A design is considered lower-level if it is instantiated by any of the designs being written out.

When this variable is set to USER, all ports on the top-level design are written with their original data types. This option affects only designs that are read in VHDL format. The default is USER.

When this variable is set to VECTOR, all ports on the top-level design are written with their ports bused. Ports keep their names (in contrast to bit-blasted ports). Port types are defined by <code>vhdlout\_bit\_vector\_type</code> or by <code>vhdlout\_bit\_type</code>, in the case of single-bit ports. For buses, the range always starts with 0 and goes in ascending order, regardless of what the range definition was in the HDL source. Ensure that <code>vhdlout\_bit\_vector\_type</code> is an array type whose elements are of <code>vhdlout\_bit\_type</code>.

When this variable is set to BIT, typed ports are bit-blasted. If the type of a port is N bits wide, it is written to the VHDL file as N separate ports. Each port is given the type defined by vhdlout\_bit\_type.

To determine the current value of this variable, use the <code>list vhdlout\_single\_bit command</code>.

## **Architecture and Configuration Variables**

The following architecture and configuration variables control the names of the architectures, configurations, and entities written to the VHDL file.

```
vhdlout_top_configuration_arch_name
```

Determines the architecture name that is written out in a configuration definition. The default value is "A".

```
vhdlout_top_configuration_entity_name
```

Determines the entity name that is written out in a configuration definition. The default value is "E".

```
vhdlout_top_configuration_name
```

Determines the configuration name that is written out in a configuration definition. The default value is "CFG TB E".

## **Preserving Port Types**

Example 7-1 shows how to write out the current design in VHDL format with port types (vector or record types) preserved.

#### Example 7-1 Preserving Port Types When Writing VHDL

```
-- The design must originate in VHDL format dc_shell> read_vhdl my_design.vhdl

-- Set the variable that causes the port types to be preserved dc_shell> set vhdlout_single_bit user

-- Now write the current design in VHDL format dc_shell> write -format vhdl -output design_out.vhdl
```

Example 7-2 shows a VHDL input file. Example 7-3 and Example 7-4 show the corresponding output files.

#### Example 7-2 Original VHDL Input File

The dc\_shell commands in Example 7-3 use the default values of the vhdlout\_variables (described in "VHDL Write Variables" on page 7-3) to generate the test\_vhdl output file.

#### Example 7-3 TEST\_VHDL Written Out in Default VHDL Format

```
library IEEE;
use IEEE.std_logic_1164.all;
package CONV_PACK_test_vhdl is
-- define attributes
attribute ENUM ENCODING : STRING;
end CONV_PACK_test_vhdl;
library IEEE;
use IEEE.std logic 1164.all;
use work.CONV_PACK_test_vhdl.all;
entity test_vhdl is
   port( a : in std_logic_vector (3 downto 0); b : out std_logic_vector
         downto 0));
end test_vhdl;
architecture SYN_structural of test_vhdl is
   component GTECH_NOT
     port( A : in std_logic; Z : out std_logic);
   end component;
begin
   I_0 : GTECH_NOT port map(A => a(3), Z => b(3));
   I_1 : GTECH_NOT port map(A => a(2), Z => b(2));
   I_2 : GTECH_NOT port map(A => a(1), Z => b(1));
   I_3 : GTECH_NOT port map(A => a(0), Z => b(0));
end SYN_structural;
```

If you set vhdlout\_single\_bit to bit, the output file generated is shown in Example 7-4.

#### Example 7-4 TEST\_VHDL Written Out With Port Types in VHDL Format

```
library IEEE;
use IEEE.std_logic_1164.all;
entity test_vhdl is
   port( a_3_port, a_2_port, a_1_port, a_0_port : in std_logic;
b 3 port,
         b_2_port, b_1_port, b_0_port : out std_logic);
end test_vhdl;
architecture SYN_structural of test_vhdl is
   component GTECH_NOT
     port( A : in std_logic; Z : out std_logic);
   end component;
begin
   I_0 : GTECH_NOT port map( A => a_3_port, Z => b_3_port);
   I_1 : GTECH_NOT port map( A => a_2_port, Z => b_2_port);
   I_2 : GTECH_NOT port map( A => a_1_port, Z => b_1_port);
   I_3 : GTECH_NOT port map( A => a_0_port, Z => b_0_port);
end SYN structural;
```

## **VHDL Netlister Coding Considerations**

To understand how the VHDL netlister writes out designs, you need to be familiar with the following coding considerations:

- Built-In Type Conversion Function
- How the Netlister Handles Custom Types
- Case Sensitivity

These issues are discussed in the nest sections.

## **Built-In Type Conversion Function**

The VHDL netlister does not use packages and does not check for type equivalence. If you do not provide your own type conversion functions, the VHDL netlister translates only the logic values 0 and 1. Example 7-5 shows the VHDL netlister's built-in type conversion function that converts from type std\_logic\_vector to type my\_bit.

#### Example 7-5 Type Conversion Function

```
-- User-defined type declaration
attribute ENUM_ENCODING : STRING;
type my_bit is (A, B, C);
attribute ENUM_ENCODING of my_bit : type is "00 01 11";
-- std_logic_vector to enum type function
function std_logic_vector_to_my_bit(arg : in std_logic_vector ( 1 to 2 ))
return my_bit is
-- synopsys built_in SYN_FEED_THRU;
begin
         case arg is
               when "00" => return A;
               when "01" \Rightarrow return B;
               when "11" => return C;
               when others => assert FALSE -- this should not happen.
                     report "un-convertible value"
                     severity warning;
                     return A;
         end case;
end;
```

## **How the Netlister Handles Custom Types**

All types you use should be resolved. If types are not resolved, the VHDL netlister uses built-in resolution functions to resolve conflicts between multiple drivers on the same signal. Use the following functions to specify your own resolution function to the VHDL netlister:

```
vhdlout_three_state_res_func
vhdlout_wired_and_res_func
vhdlout wired or res func
```

Example 7-6 shows the resolution function the VHDL netlister writes out. This resolution function is used to resolve the value for multiple sources driving a signal, port, or pin.

#### Example 7-6 VHDL Resolution Function

```
function X( inputs : in vhdlout_bit_vector_type ) return vhdlout_bit_type is
-- synopsys resolution_method three_state
variable retval: vhdlout_bit_type;
begin
  retval := vhdlout_three_state_name;
         for i in inputs'range loop
          if inputs(i) /= vhdlout_three_state_name then
                  if ( retval = vhdlout_three_state_name ) then
                            retval := inputs(i);
                      else
                          retval := vhdlout unknown name
                            exit:
                      end if;
               end if;
         end loop:
return retval;
end X;
```

Example 7-7 shows a simplified description of the process flow for the resolution function in Example 7-6.

In this example, the <code>vhdlout\_three\_state\_name</code> and <code>vhdlout\_unknown\_name</code> variables use the default values z and x, respectively, for brevity. You can set the values for both of these variables.

#### Example 7-7 Pseudocode of VHDL Resolution Function

```
if the only logic values are 'z'
    return 'z'
if there are 'z's and another logic value
    return the other logic value
if there are non-'z' logic values that are different
    return 'x'
else
    return the common logic value
```

### **Case Sensitivity**

The VHDL netlist writer is case insensitive. For example, \A and \a are considered to be unique identifiers; however, the VHDL netlist writer considers them to be the same identifier.

Note that the VHDL netlist reader is case sensitive and supports the VHDL 93 standard.



# Examples

Source files for examples demonstrating the use of VHDL are typically in the /synopsys/syn/examples/vhdl directory. These examples are included in the following sections:

- Read-Only Memory
- Waveform Generator
- Definable-Width Adder-Subtracter
- Count Zeros—Combinational Version
- Count Zeros—Sequential Version
- Soft Drink Machine—State Machine Version
- Soft Drink Machine—Count Nickels Version
- FSM Example: Moore Machine
- FSM Example: Mealy Machine
- Carry-Lookahead Adder
- Serial-to-Parallel Converter—Counting Bits
- Serial-to-Parallel Converter—Shifting Bits
- Programmable Logic Arrays

# **Read-Only Memory**

Example A-1 on page A-3 shows how you can define a read-only memory in VHDL. The ROM is defined as an array constant, ROM. Each line of the constant array specification defines the contents of one ROM address. To read from the ROM, index into the array.

The number of ROM storage locations and bit-width is easy to change. The subtype ROM\_RANGE specifies that the ROM contains storage locations 0 to 7. The constant ROM WIDTH specifies that the ROM is 5 bits wide.

After you define a ROM constant, you can index into that constant many times to read many values from the ROM. If the ROM address is computable, no logic is built and the appropriate data value is inserted. If the ROM address is not computable, logic is built for each index into the value. For this reason, consider resource sharing when using a ROM. In Example A-1 on page A-3, ADDR is not computable, so logic is synthesized to compute the value.

Presto VHDL does not actually instantiate a typical array-logic ROM, such as those available from ASIC vendors. Instead, it creates the ROM from random logic gates (AND, OR, NOT, and so on). This type of implementation is preferable for small ROMs and for ROMs that are regular. For very large ROMs, consider using an array-logic implementation supplied by your ASIC vendor.

Example A-1 on page A-3 shows the VHDL source code and the synthesized circuit schematic.

### Example A-1 Implementation of a ROM in Random Logic

```
package ROMS is
  -- declare a 5x8 ROM called ROM
  constant ROM_WIDTH: INTEGER := 5;
  subtype ROM_WORD is BIT_VECTOR (1 to ROM_WIDTH);
  subtype ROM_RANGE is INTEGER range 0 to 7;
  type ROM_TABLE is array (0 to 7) of ROM_WORD;
  constant ROM: ROM_TABLE := ROM_TABLE'(
      ROM_WORD'("10101"),
                                        -- ROM contents
      ROM_WORD'("10000"),
      ROM_WORD'("11111"),
      ROM_WORD'("11111"),
      ROM_WORD'("10000"),
      ROM_WORD'("10101"),
      ROM_WORD'("11111"),
      ROM_WORD'("11111"));
end ROMS;
                   -- Entity that uses ROM
use work.ROMS.all;
entity ROM_5x8 is
  port(ADDR: in ROM_RANGE;
       DATA: out ROM_WORD);
architecture BEHAVIOR of ROM_5x8 is
begin
                         -- Read from the ROM
  DATA <= ROM(ADDR);</pre>
end BEHAVIOR;
```



### **Waveform Generator**

The waveform generator example shows how to use the previous ROM example to implement a waveform generator.

Assume that you want to produce the waveform output shown in Figure A-1.

- 1. First, declare a ROM wide enough to hold the output signals (4 bits) and deep enough to hold all time steps (0 to 12, for a total of 13).
- 2. Next, define the ROM so that each time step is represented by an entry in the ROM.
- 3. Finally, create a counter that cycles through the time steps (ROM addresses), generating the waveform at each time step.

Figure A-1 Waveform Example



Example A-2 shows an implementation for the waveform generator. It consists of a ROM, a counter, and some simple reset logic.

### Example A-2 Implementation of a Waveform Generator

```
package ROMS is
  -- a 4x13 ROM called ROM that contains the waveform
  constant ROM_WIDTH: INTEGER := 4;
  subtype ROM_WORD is BIT_VECTOR (1 to ROM_WIDTH);
  subtype ROM_RANGE is INTEGER range 0 to 12;
  type ROM_TABLE is array (0 to 12) of ROM_WORD;
  constant ROM: ROM_TABLE := ROM_TABLE'(
      "1100", -- time step 0
              -- time step 1
      "1100",
              -- time step 2
      "0100",
      "0000",
              -- time step 3
               -- time step 4
      "0110",
      "0101",
               -- time step 5
      "0111",
               -- time step 6
      "1100",
               -- time step 7
      "0100", -- time step 8
      "0000", -- time step 9
      "0110", -- time step 10
      "0101", -- time step 11
      "0111"); -- time step 12
end ROMS:
use work.ROMS.all;
entity WAVEFORM is
                        -- Waveform generator
 port(CLOCK: in BIT;
      RESET: in BOOLEAN;
      WAVES: out ROM_WORD);
end;
architecture BEHAVIOR of WAVEFORM is
  signal STEP: ROM_RANGE;
begin
  TIMESTEP_COUNTER: process -- Time stepping process
  begin
   wait until CLOCK'event and CLOCK = '1';
    if RESET then -- Detect reset
     STEP <= ROM_RANGE'low; -- Restart</pre>
   elsif STEP = ROM_RANGE'high then -- Finished?
     STEP <= ROM_RANGE'high; -- Hold at last value</pre>
   -- STEP <= ROM_RANGE'low; -- Continuous wave
   else
      STEP <= STEP + 1; -- Continue stepping
    end if;
  end process TIMESTEP_COUNTER;
 WAVES <= ROM(STEP);
end BEHAVIOR;
```

When the counter STEP reaches the end of the ROM, STEP stops, generates the last value, then waits until a reset. To make the sequence automatically repeat, remove the following statement:

```
STEP <= ROM_RANGE'high; -- Hold at last value
Use the following statement instead (commented out in Example A-2 on page A-5):
STEP <= ROM_RANGE'low; -- Continuous wave</pre>
```

### **Definable-Width Adder-Subtracter**

VHDL lets you create functions for use with array operands of any size. This example shows an adder-subtracter circuit that, when called, is adjusted to fit the size of its operands.

Example A-3 shows an adder-subtracter defined for two unconstrained arrays of bits (type BIT\_VECTOR) in a package named MATH. When an unconstrained array type is used for an argument to a subprogram, the actual constraints of the array are taken from the actual parameter values in a subprogram call.

### Example A-3 MATH Package for Example A-4 on page A-7

```
package MATH is
  function ADD SUB(L, R: BIT VECTOR; ADD: BOOLEAN)
     return BIT_VECTOR;
    -- Add or subtract two BIT_VECTORs of equal length
end MATH;
package body MATH is
    function ADD_SUB(L, R: BIT_VECTOR; ADD: BOOLEAN)
        return BIT VECTOR is
      variable CARRY: BIT;
      variable A, B, SUM:
          BIT VECTOR(L'length-1 downto 0);
    begin
      if ADD then
          -- Prepare for an "add" operation
          A := L;
          B := R;
          CARRY := '0';
      else
          -- Prepare for a "subtract" operation
          A := L;
          B := not R;
          CARRY := '1';
      end if;
      -- Create a ripple carry chain; sum up bits
      for i in 0 to A'left loop
```

Within the function ADD\_SUB, two temporary variables, A and B, are declared. These variables are declared to be the same length as L (and necessarily, R) but have their index constraints normalized to L'length-1 downto 0. After the arguments are normalized, you can create a ripple carry adder by using a for loop.

No explicit references to a fixed array length are in the function ADD\_SUB. Instead, the VHDL array attributes 'left and 'length are used. These attributes allow the function to work on arrays of any length.

Example A-4 shows how to use the adder-subtracter defined in the MATH package. In this example, the vector arguments to functions ARG1 and ARG2 are declared as BIT\_VECTOR(1 to 6). This declaration causes ADD\_SUB to work with 6-bit arrays.

### Example A-4 Implementation of a 6-Bit Adder-Subtracter

```
use work.MATH.all;
entity EXAMPLE is
    port(ARG1, ARG2: in BIT_VECTOR(1 to 6);
        ADD: in BOOLEAN;
        RESULT : out BIT_VECTOR(1 to 6));
end EXAMPLE;

architecture BEHAVIOR of EXAMPLE is
begin
    RESULT <= ADD_SUB(ARG1, ARG2, ADD);
end BEHAVIOR;</pre>
```

### **Count Zeros—Combinational Version**

The count zeros—combinational example, Example A-5 on page A-8, illustrates a design problem in which an 8-bit-wide value is given and the circuit determines two things:

- That no more than one sequence of zeros is in the value.
- The number of zeros in that sequence (if any). This computation must be completed in a single clock cycle.

The circuit produces two outputs: the number of zeros found and an error indication.

A valid input value can have at most one consecutive series of zeros. A value consisting entirely of ones is defined as a valid value. If a value is invalid, the zero counter resets to 0. For example, the value 00000000 is valid and has eight zeros; value 11000111 is valid and has three zeros; value 00111100 is invalid.

Example A-5 shows the VHDL description for the circuit. It consists of a single process with a for loop that iterates across each bit in the given value. At each iteration, a temporary INTEGER variable (TEMP\_COUNT) counts the number of zeros encountered. Two temporary Boolean variables (SEEN\_ZERO and SEEN\_TRAILING), initially false, are set to true when the beginning and end of the first sequence of zeros are detected.

If a zero is detected after the end of the first sequence of zeros (after SEEN\_TRAILING is true), the zero count is reset (to 0), ERROR is set to true, and the for loop is exited.

Example A-5 shows a combinational (parallel) approach to counting the zeros. The next example shows a sequential (serial) approach.

### Example A-5 Count Zeros—Combinational

```
entity COUNT_COMB_VHDL is
  port(DATA: in BIT_VECTOR(7 downto 0);
       COUNT: out INTEGER range 0 to 8;
       ERROR: out BOOLEAN);
end:
architecture BEHAVIOR of COUNT_COMB_VHDL is
begin
  process (DATA)
    variable TEMP_COUNT : INTEGER range 0 to 8;
    variable SEEN ZERO, SEEN TRAILING: BOOLEAN;
  begin
    ERROR <= FALSE;</pre>
    SEEN ZERO := FALSE;
    SEEN_TRAILING := FALSE;
    TEMP COUNT := 0;
    for I in 0 to 7 loop
      if (SEEN_TRAILING and DATA(I) = '0') then
        TEMP\_COUNT := 0;
        ERROR <= TRUE;</pre>
        exit;
      elsif (SEEN_ZERO and DATA(I) = '1') then
        SEEN_TRAILING := TRUE;
      elsif (DATA(I) = '0') then
        SEEN_ZERO := TRUE;
        TEMP COUNT := TEMP COUNT + 1;
      end if;
    end loop;
    COUNT <= TEMP_COUNT;
  end process;
```

end BEHAVIOR;

# **Count Zeros—Sequential Version**

The count zeros—sequential example, Example A-6 on page A-10, shows a sequential (clocked) variant of the preceding design (Count Zeros—Combinational Version).

The circuit now accepts the 8-bit data value serially, 1 bit per clock cycle, by using the DATA and CLK inputs. The other two inputs are

- · RESET, which resets the circuit
- READ, which causes the circuit to begin accepting data bits

The circuit's three outputs are

- IS\_LEGAL, which is true if the data was a valid value
- COUNT\_READY, which is true at the first invalid bit or when all 8 bits have been processed
- COUNT, the number of zeros (if IS\_LEGAL is true)

#### Note:

The output port COUNT is declared with mode BUFFER so that it can be read inside the process. OUT ports can only be written to, not read in.

### Example A-6 Count Zeros—Sequential

```
entity COUNT_SEQ_VHDL is
  port(DATA, CLK: in BIT;
       RESET, READ: in BOOLEAN;
       COUNT: buffer INTEGER range 0 to 8;
       IS_LEGAL: out BOOLEAN;
       COUNT_READY: out BOOLEAN);
architecture BEHAVIOR of COUNT SEQ VHDL is
begin
  process
    variable SEEN_ZERO, SEEN_TRAILING: BOOLEAN;
    variable BITS_SEEN: INTEGER range 0 to 7;
    wait until CLK'event and CLK = '1';
    if(RESET) then
      COUNT_READY <= FALSE;
                                 -- signal assignment
-- variable assignment
      IS_LEGAL <= TRUE;
SEEN_ZERO := FALSE;
      SEEN_TRAILING := FALSE;
      COUNT
                     <= 0;
      BITS_SEEN
                     := 0;
    else
      if (READ) then
        if (SEEN_TRAILING and DATA = '0') then
          IS LEGAL <= FALSE;
          COUNT <= 0;
          COUNT_READY <= TRUE;
        elsif (SEEN_ZERO and DATA = '1') then
          SEEN_TRAILING := TRUE;
        elsif (DATA = '0') then
          SEEN ZERO := TRUE;
          COUNT <= COUNT + 1;
        end if;
        if (BITS\_SEEN = 7) then
          COUNT_READY <= TRUE;
          BITS_SEEN := BITS_SEEN + 1;
        end if;
      end if; -- if (READ)
                -- if (RESET)
    end if;
  end process;
end BEHAVIOR;
```

### Soft Drink Machine—State Machine Version

The soft drink machine—state machine example, Example A-7, is a control unit for a soft drink vending machine.

The circuit reads signals from a coin input unit and sends outputs to a change dispensing unit and a drink dispensing unit.

Here are the design parameters for Example A-7 and Example A-8 on page A-14:

- This example assumes that only one kind of soft drink is dispensed.
- This is a clocked design with CLK and RESET input signals.
- The price of the drink is 35 cents.
- The input signals from the coin input unit are NICKEL\_IN (nickel deposited), DIME\_IN (dime deposited), and QUARTER\_IN (quarter deposited).
- The output signals to the change dispensing unit are NICKEL\_OUT and DIME\_OUT.
- The output signal to the drink dispensing unit is DISPENSE (dispense drink).

The first VHDL description for this design uses a state machine description style. The second VHDL description is in Example A-8 on page A-14.

### Example A-7 Soft Drink Machine—State Machine

```
library synopsys; use synopsys.attributes.all;
entity DRINK_STATE_VHDL is
  port(NICKEL_IN, DIME_IN, QUARTER_IN, RESET: BOOLEAN;
       CLK: BIT;
       NICKEL OUT, DIME OUT, DISPENSE: out BOOLEAN);
end;
architecture BEHAVIOR of DRINK_STATE_VHDL is
  type STATE_TYPE is (IDLE, FIVE, TEN, FIFTEEN,
                  TWENTY, TWENTY_FIVE, THIRTY, OWE_DIME);
  signal CURRENT STATE, NEXT STATE: STATE TYPE;
  attribute STATE_VECTOR : STRING;
  attribute STATE_VECTOR of BEHAVIOR : architecture is
                           "CURRENT STATE";
attribute sync_set_reset of reset : signal is "true";
begin
  process(NICKEL_IN, DIME_IN, QUARTER_IN,
          CURRENT_STATE, RESET, CLK)
  begin
    -- Default assignments
    NEXT STATE <= CURRENT STATE;
```

```
NICKEL OUT <= FALSE;
DIME OUT <= FALSE;
DISPENSE <= FALSE;
-- Synchronous reset
if(RESET) then
 NEXT STATE <= IDLE;
else
  -- State transitions and output logic
  case CURRENT_STATE is
    when IDLE =>
      if (NICKEL IN) then
        NEXT_STATE <= FIVE;</pre>
      elsif(DIME_IN) then
        NEXT_STATE <= TEN;</pre>
      elsif(QUARTER_IN) then
        NEXT_STATE <= TWENTY_FIVE;</pre>
      end if;
    when FIVE =>
      if(NICKEL_IN) then
        NEXT_STATE <= TEN;
      elsif(DIME_IN) then
        NEXT STATE <= FIFTEEN;
      elsif(QUARTER_IN) then
        NEXT_STATE <= THIRTY;</pre>
      end if;
    when TEN =>
      if(NICKEL_IN) then
        NEXT_STATE <= FIFTEEN;</pre>
      elsif(DIME_IN) then
        NEXT_STATE <= TWENTY;</pre>
      elsif(QUARTER_IN) then
        NEXT_STATE <= IDLE;</pre>
        DISPENSE <= TRUE;
      end if;
    when FIFTEEN =>
      if(NICKEL_IN) then
        NEXT_STATE <= TWENTY;</pre>
      elsif(DIME_IN) then
        NEXT_STATE <= TWENTY_FIVE;</pre>
      elsif(QUARTER_IN) then
        NEXT_STATE <= IDLE;</pre>
        DISPENSE <= TRUE;</pre>
        NICKEL_OUT <= TRUE;
      end if;
    when TWENTY =>
      if (NICKEL IN) then
        NEXT_STATE <= TWENTY_FIVE;</pre>
      elsif(DIME_IN) then
        NEXT_STATE <= THIRTY;</pre>
      elsif(QUARTER_IN) then
```

```
NEXT STATE <= IDLE;
             DISPENSE <= TRUE;
             DIME_OUT <= TRUE;</pre>
           end if;
        when TWENTY_FIVE =>
           if (NICKEL IN) then
            NEXT_STATE <= THIRTY;</pre>
           elsif(DIME_IN) then
            NEXT_STATE <= IDLE;</pre>
             DISPENSE <= TRUE;
           elsif(QUARTER_IN) then
             NEXT STATE <= IDLE;
             DISPENSE <= TRUE;</pre>
             DIME_OUT <= TRUE;</pre>
             NICKEL_OUT <= TRUE;</pre>
           end if;
        when THIRTY =>
           if(NICKEL_IN) then
            NEXT_STATE <= IDLE;</pre>
             DISPENSE <= TRUE;
           elsif(DIME_IN) then
            NEXT_STATE <= IDLE;</pre>
             DISPENSE <= TRUE;
             NICKEL_OUT <= TRUE;
           elsif(QUARTER_IN) then
             NEXT_STATE <= OWE_DIME;</pre>
             DISPENSE <= TRUE;
             DIME_OUT <= TRUE;</pre>
           end if;
        when OWE_DIME =>
          NEXT_STATE <= IDLE;</pre>
          DIME_OUT <= TRUE;</pre>
      end case;
    end if;
  end process;
  -- Synchronize state value with clock
  -- This causes it to be stored in flip-flops
 process
 begin
    wait until CLK'event and CLK = '1';
    CURRENT_STATE <= NEXT_STATE;
  end process;
end BEHAVIOR;
```

### Soft Drink Machine—Count Nickels Version

The soft drink machine—count nickels example, Example A-8, uses the same design parameters as the preceding Example A-7 on page A-11 (Soft Drink Machine—State Machine Version), with the same input and output signals. In this version, a counter counts the number of nickels deposited. This counter is incremented by 1 if the deposit is a nickel, by 2 if it is a dime, and by 5 if it is a quarter.

### Example A-8 Soft Drink Machine—Count Nickels

```
entity DRINK_COUNT_VHDL is
  port(NICKEL_IN, DIME_IN, QUARTER_IN, RESET: BOOLEAN;
       CLK: BIT:
       NICKEL_OUT, DIME_OUT, DISPENSE: out BOOLEAN);
end;
architecture BEHAVIOR of DRINK_COUNT_VHDL is
  signal CURRENT_NICKEL_COUNT,
         NEXT_NICKEL_COUNT: INTEGER range 0 to 7;
  signal CURRENT_RETURN_CHANGE, NEXT_RETURN_CHANGE : BOOLEAN;
begin
  process(NICKEL_IN, DIME_IN, QUARTER_IN, RESET, CLK,
          CURRENT_NICKEL_COUNT, CURRENT_RETURN_CHANGE)
    variable TEMP_NICKEL_COUNT: INTEGER range 0 to 12;
    -- Default assignments
   NICKEL_OUT <= FALSE;
    DIME_OUT <= FALSE;</pre>
   DISPENSE <= FALSE;
   NEXT_NICKEL_COUNT <= 0;</pre>
   NEXT RETURN CHANGE <= FALSE;
    -- Synchronous reset
    if (not RESET) then
      TEMP_NICKEL_COUNT := CURRENT_NICKEL_COUNT;
      -- Check whether money has come in
      if (NICKEL_IN) then
        -- NOTE: This design will be flattened, so
        -- these multiple adders will be optimized
        TEMP_NICKEL_COUNT := TEMP_NICKEL_COUNT + 1;
      elsif(DIME_IN) then
        TEMP_NICKEL_COUNT := TEMP_NICKEL_COUNT + 2;
      elsif(QUARTER_IN) then
        TEMP_NICKEL_COUNT := TEMP_NICKEL_COUNT + 5;
      end if;
      -- Enough deposited so far?
      if(TEMP_NICKEL_COUNT >= 7) then
        TEMP_NICKEL_COUNT := TEMP_NICKEL_COUNT - 7;
        DISPENSE <= TRUE;
      end if;
      -- Return change
      if(TEMP_NICKEL_COUNT >= 1 or
```

```
CURRENT_RETURN_CHANGE) then
        if(TEMP_NICKEL_COUNT >= 2) then
          DIME_OUT <= TRUE;</pre>
          TEMP_NICKEL_COUNT := TEMP_NICKEL_COUNT - 2;
          NEXT_RETURN_CHANGE <= TRUE;</pre>
        end if;
        if(TEMP_NICKEL_COUNT = 1) then
          NICKEL OUT <= TRUE;
          TEMP_NICKEL_COUNT := TEMP_NICKEL_COUNT - 1;
        end if;
      end if;
      NEXT_NICKEL_COUNT <= TEMP_NICKEL_COUNT;</pre>
    end if;
  end process;
  -- Remember the return-change flag and
  -- the nickel count for the next cycle
  begin
   wait until CLK'event and CLK = '1';
   CURRENT_RETURN_CHANGE <= NEXT_RETURN_CHANGE;
    CURRENT_NICKEL_COUNT <= NEXT_NICKEL_COUNT;
  end process;
end BEHAVIOR;
```

# **FSM Example: Moore Machine**

Figure A-2 is a diagram of a simple Moore finite state machine. It has one input (X), four internal states (S0 to S3), and one output (Z).

Figure A-2 Moore Machine Specification



The VHDL code implementing this finite state machine is shown in Example A-9.

The machine description includes two processes. One process defines the synchronous elements of the design (state registers); the other process defines the combinational part of the design (state assignment case statement).

### Example A-9 Implementation of a Moore Machine

```
Z <= '0';
        if X = '0' then
          NEXT_STATE <= S0;
        else
          NEXT_STATE <= S2;</pre>
        end if;
      when S1 =>
        Z <= '1';
        if X = '0' then
          NEXT_STATE <= S0;</pre>
        else
          NEXT_STATE <= S2;</pre>
        end if;
      when S2 =>
        Z <= '1';
        if X = '0' then
          NEXT_STATE <= S2;</pre>
          NEXT STATE <= S3;
        end if;
      when S3 =>
        Z <= '0';
        if X = '0' then
          NEXT_STATE <= S3;</pre>
          NEXT_STATE <= S1;</pre>
        end if;
    end case;
  end process;
  -- Process to hold synchronous elements (flip-flops)
  SYNCH: process
  begin
    wait until CLOCK'event and CLOCK = '1';
    CURRENT_STATE <= NEXT_STATE;</pre>
  end process;
end BEHAVIOR;
```

# **FSM Example: Mealy Machine**

Figure A-3 is a diagram of a simple Mealy finite state machine. The VHDL code for implementing this finite state machine is shown in Example A-10. The machine description includes two processes, as in the previous Moore machine example.

Figure A-3 Mealy Machine Specification



### Example A-10 Implementation of a Mealy Machine

```
entity MEALY is
                            -- Mealy machine
  port(X, CLOCK: in BIT;
       Z: out BIT);
end;
architecture BEHAVIOR of MEALY is
  type STATE_TYPE is (S0, S1, S2, S3);
  signal CURRENT_STATE, NEXT_STATE: STATE_TYPE;
begin
  -- Process to hold combinational logic.
  COMBIN: process(CURRENT_STATE, X)
  begin
    case CURRENT_STATE is
      when S0 =>
        if X = '0' then
          Z <= '0';
          NEXT_STATE <= S0;</pre>
        else
          Z <= '1';
```

```
NEXT STATE <= S2;
         end if;
      when S1 =>
        if X = '0' then
          Z <= '0';
          NEXT_STATE <= S0;</pre>
           Z <= '0';
          NEXT_STATE <= S2;</pre>
         end if;
      when S2 =>
        if X = '0' then
           Z <= '1';
          NEXT_STATE <= S2;</pre>
         else
           Z <= '0';
          NEXT_STATE <= S3;</pre>
         end if;
      when S3 =>
         if X = '0' then
          Z <= '0';
          NEXT_STATE <= S3;</pre>
         else
           Z <= '1';
          NEXT_STATE <= S1;</pre>
         end if;
    end case;
  end process;
  -- Process to hold synchronous elements (flip-flops)
  SYNCH: process
  begin
    wait until CLOCK'event and CLOCK = '1';
    CURRENT_STATE <= NEXT_STATE;</pre>
  end process;
end BEHAVIOR;
```



# **Carry-Lookahead Adder**

This example uses concurrent procedure calls to build a 32-bit carry-lookahead adder. The adder is built by partitioning of the 32-bit input into eight slices of 4 bits each. Each of the eight slices computes propagate and generate values by using the PG procedure.

Propagate (output P from PG) is '1' for a bit position if that position propagates a carry from the next-lower position to the next-higher position. Generate (output G) is '1' for a bit position if that position generates a carry to the next-higher position, regardless of the carry-in from the next lower position. The carry-lookahead logic reads the carry-in, propagate, and generate information computed from the inputs. The logic computes the carry value for each bit position and makes the addition operation an XOR of the inputs and the carry values.

### **Carry Value Computations**

The carry values are computed by a three-level tree of 4-bit carry-lookahead blocks.

- The first level of the tree computes the 32 carry values and the eight group-propagate and generate values. Each of the first-level group-propagate and generate values tells if that 4-bit slice propagates and generates carry values from the next-lower group to the next-higher group. The first-level lookahead blocks read the group carry computed at the second level.
- The second-level lookahead blocks read the group-propagate and generate information from the four first-level blocks and then compute their own group-propagate and generate information. The second-level lookahead blocks also read group carry information computed at the third level to compute the carries for each of the third-level blocks.
- The third-level block reads the propagate and generate information of the second level to compute a propagate and generate value for the entire adder. It also reads the external carry to compute each second-level carry. The carry-out for the adder is '1' if the third-level generate is '1' or if the third-level propagate is '1' and the external carry is '1'.

The third-level carry-lookahead block is capable of processing four second-level blocks. But because there are only two second-level blocks, the high-order 2 bits of the computed carry are ignored; the high-order 2 bits of the generate input to the third-level are set to 0, "00", and the propagate high-order bits are set to "11". These settings cause the unused portion to propagate carries but not to generate them. Figure A-4 shows the overall structure for the carry-lookahead adder.



Figure A-4 Carry-Lookahead Adder Block Diagram

The VHDL implementation of the design in Figure A-4 is accomplished with the following procedures:

### CLA

Names a 4-bit carry-lookahead block.

### PG

Computes first-level propagate and generate information.

#### SUM

Computes the sum by adding the XOR values to the inputs with the carry values computed by CLA.

#### **BITSLICE**

Collects the first-level CLA blocks, the PG computations, and the SUM. This procedure performs all the work for a 4-bit value except for the second- and third-level lookaheads.

Example A-11 shows a VHDL description of the adder.

### Example A-11 Carry-Lookahead Adder

```
package LOCAL is
 constant N: INTEGER := 4;
 procedure BITSLICE(
     A, B: in BIT_VECTOR(3 downto 0);
     CIN: in BIT;
     signal S: out BIT_VECTOR(3 downto 0);
     signal GP, GG: out BIT);
 procedure PG(
     A, B: in BIT VECTOR(3 downto 0);
     P, G: out BIT_VECTOR(3 downto 0));
  function SUM(A, B, C: BIT_VECTOR(3 downto 0))
     return BIT_VECTOR;
 procedure CLA(
     P, G: in BIT_VECTOR(3 downto 0);
     CIN: in BIT;
     C: out BIT_VECTOR(3 downto 0);
     signal GP, GG: out BIT);
end LOCAL;
package body LOCAL is
 ______
  -- Compute sum and group outputs from a, b, cin
 procedure BITSLICE(
     A, B: in BIT_VECTOR(3 downto 0);
     CIN: in BIT;
     signal S: out BIT_VECTOR(3 downto 0);
     signal GP, GG: out BIT) is
   variable P, G, C: BIT_VECTOR(3 downto 0);
 begin
   PG(A, B, P, G);
```

```
CLA(P, G, CIN, C, GP, GG);
   S \le SUM(A, B, C);
 end;
 -- Compute propagate and generate from input bits
 procedure PG(A, B: in BIT_VECTOR(3 downto 0);
             P, G: out BIT_VECTOR(3 downto 0)) is
 begin
   P := A \text{ or } B;
   G := A \text{ and } B;
 end;
 -- Compute sum from the input bits and the carries
 -----
 function SUM(A, B, C: BIT_VECTOR(3 downto 0))
     return BIT_VECTOR is
   return(A xor B xor C);
 end;
  _____
 -- 4-bit carry-lookahead block
 ______
 procedure CLA(
     P, G: in BIT_VECTOR(3 downto 0);
     CIN: in BIT;
     C: out BIT_VECTOR(3 downto 0);
     signal GP, GG: out BIT) is
   variable TEMP_GP, TEMP_GG, LAST_C: BIT;
   TEMP\_GP := P(0);
   TEMP\_GG := G(0);
   LAST_C := CIN;
   C(0) := CIN;
   for I in 1 to N-1 loop
     TEMP_GP := TEMP_GP and P(I);
     TEMP_GG := (TEMP_GG and P(I)) or G(I);
     LAST_C := (LAST_C \text{ and } P(I-1)) or G(I-1);
     C(I) := LAST_C;
   end loop;
   GP <= TEMP_GP;
   GG <= TEMP_GG;
 end;
end LOCAL;
use WORK.LOCAL.ALL;
```

\_\_\_\_\_\_

```
-- A 32-bit carry-lookahead adder
______
entity ADDER is
 port(A, B: in BIT_VECTOR(31 downto 0);
      CIN: in BIT;
      S: out BIT_VECTOR(31 downto 0);
      COUT: out BIT);
end ADDER;
architecture BEHAVIOR of ADDER is
 signal GG,GP,GC: BIT_VECTOR(7 downto 0);
    -- First-level generate, propagate, carry
 signal GGG, GGP, GGC: BIT_VECTOR(3 downto 0);
    -- Second-level gen, prop, carry
 signal GGGG, GGGP: BIT;
   -- Third-level gen, prop
begin
 -- Compute Sum and 1st-level Generate and Propagate
 -- Use input data and the 1st-level Carries computed
 -- later.
 BITSLICE(A(11 downto 8),B(11 downto 8),GC(2),
          S(11 downto 8), GP(2), GG(2));
 BITSLICE (A(15 downto 12), B(15 downto 12), GC(3),
          S(15 \text{ downto } 12), GP(3), GG(3));
 BITSLICE(A(19 downto 16), B(19 downto 16), GC(4),
          S(19 \text{ downto } 16), GP(4), GG(4));
 BITSLICE(A(23 downto 20), B(23 downto 20), GC(5),
          S(23 downto 20), GP(5), GG(5));
 BITSLICE(A(27 downto 24), B(27 downto 24), GC(6),
          S(27 downto 24), GP(6), GG(6));
 BITSLICE(A(31 downto 28), B(31 downto 28), GC(7),
          S(31 \text{ downto } 28), GP(7), GG(7));
 -- Compute first-level Carries and second-level
 -- generate and propagate.
  -- Use first-level Generate, Propagate, and
  -- second-level carry.
 process(GP, GG, GGC)
   variable TEMP: BIT_VECTOR(3 downto 0);
 begin
   CLA(GP(3 downto 0), GG(3 downto 0), GGC(0), TEMP,
       GGP(0), GGG(0));
   GC(3 downto 0) <= TEMP;
 end process;
 process(GP, GG, GGC)
   variable TEMP: BIT_VECTOR(3 downto 0);
 begin
   CLA(GP(7 downto 4), GG(7 downto 4), GGC(1), TEMP,
       GGP(1), GGG(1));
   GC(7 downto 4) <= TEMP;
 end process;
```

```
-- Compute second-level Carry and third-level
 -- Generate and Propagate
 -- Use second-level Generate, Propagate and Carry-in
 -- (CIN)
 process(GGP, GGG, CIN)
   variable TEMP: BIT_VECTOR(3 downto 0);
   CLA(GGP, GGG, CIN, TEMP, GGGP, GGGG);
   GGC <= TEMP;
 end process;
 -- Assign unused bits of second-level Generate and
 -- Propagate
 GGP(3 downto 2) <= "11";
 GGG(3 downto 2) <= "00";
 -- Compute Carry-out (COUT)
 -- Use third-level Generate and Propagate and
 -- Carry-in (CIN).
 COUT <= GGGG or (GGGP and CIN);
end BEHAVIOR:
```

### **Implementation**

In the carry-lookahead adder implementation, procedures perform the computation of the design. The procedures can also be in the form of separate entities and used by component instantiation, producing a hierarchical design. Presto VHDL does not collapse a hierarchy of entities, but it does collapse the procedure call hierarchy into one design.

The keyword *signal* is included before some of the interface parameter declarations. This keyword is required for the out formal parameters when the actual parameters must be signals.

The output parameter C from the CLA procedure is not declared as a signal; thus, it is not allowed in a concurrent procedure call. Only signals can be used in such calls. To overcome this problem, subprocesses are used, declaring a temporary variable TEMP. TEMP receives the value of the C parameter and assigns it to the appropriate signal (a generally useful technique).

# **Serial-to-Parallel Converter—Counting Bits**

This example shows the design of a serial-to-parallel converter that reads a serial, bit-stream input and produces an 8-bit output.

The design reads the following inputs:

### SERIAL IN

The serial input data.

#### RESET

The input that, when it is '1', causes the converter to reset. All outputs are set to 0, and the converter is prepared to read the next serial word.

#### **CLOCK**

The value of RESET and SERIAL\_IN, which is read on the positive transition of this clock. Outputs of the converter are also valid only on positive transitions.

The design produces the following outputs:

### PARALLEL OUT

The 8-bit value read from the SERIAL\_IN port.

#### READ ENABLE

The output that, when it is '1' on the positive transition of CLOCK, causes the data on PARALLEL\_OUT to be read.

### PARITY\_ERROR

The output that, when it is '1' on the positive transition of CLOCK, indicates that a parity error has been detected on the SERIAL\_IN port. When a parity error is detected, the converter halts until restarted by the RESET port.

### **Input Format**

When no data is being transmitted to the serial port, keep it at a value of '0'. Each 8-bit value requires 10 clock cycles to read it. On the 11th clock cycle, the parallel output value can be read.

In the first cycle, a '1' is placed on the serial input. This assignment indicates that an 8-bit value follows. The next 8 cycles transmit each bit of the value. The most significant bit is transmitted first. The 10th cycle transmits the parity of the 8-bit value. It must be '0' if an even number of '1' values are in the 8-bit data, and '1' otherwise. If the converter detects a parity error, it sets the PARITY\_ERROR output to '1' and waits until the value is reset.

On the 11th cycle, the READ\_ENABLE output is set to '1' and the 8-bit value can be read from the PARALLEL\_OUT port. If the SERIAL\_IN port has a '1' on the 11th cycle, another 8-bit value is read immediately; otherwise, the converter waits until SERIAL\_IN goes to '1'.

Figure A-5 shows the timing of this design.

Figure A-5 Sample Waveform Through the Converter



### **Implementation Details**

The implementation of the converter is as a four-state finite-state machine with synchronous reset. When a reset is detected, the converter enters a WAIT\_FOR\_START state. Description of the states follow.

### WAIT FOR START

Stay in this state until a '1' is detected on the serial input. When a '1' is detected, clear the PARALLEL\_OUT registers and go to the READ\_BITS state.

#### **READ BITS**

If the value of the current\_bit\_position counter is 8, all 8 bits have been read. Check the computed parity with the transmitted parity. If it is correct, go to the ALLOW\_READ state; otherwise, go to the PARITY\_ERROR state.

If all 8 bits have not yet been read, set the appropriate bit in the PARALLEL\_OUT buffer to the SERIAL\_IN value, compute the parity of the bits read so far, and increment the current bit position.

### ALLOW READ

This is the state where the outside world reads the PARALLEL\_OUT value. When that value is read, the design returns to the WAIT\_FOR\_START state.

### PARITY ERROR DETECTED

In this state, the PARITY\_ERROR output is set to '1' and nothing else is done.

This design has four values stored in registers:

### **CURRENT STATE**

Remembers the state as of the last clock edge.

### CURRENT\_BIT\_POSITION

Remembers how many bits have been read so far.

### **CURRENT PARITY**

Keeps a running XOR of the bits read.

### CURRENT PARALLEL OUT

Stores each parallel bit as it is found.

The design has two processes: the combinational NEXT\_ST containing the combinational logic and the sequential SYNCH that is clocked.

NEXT\_ST performs all the computations and state assignments. The NEXT\_ST process starts by assigning default values to all the signals it drives. This assignment guarantees that all signals are driven under all conditions. Next, the RESET input is processed. If RESET is not active, a case statement determines the current state and its computations. State transitions are performed by assignment of the next state's value you want to the NEXT\_STATE signal.

The serial-to-parallel conversion itself is performed by these two statements in the NEXT\_ST process:

```
NEXT_PARALLEL_OUT(CURRENT_BIT_POSITION) <= SERIAL_IN;
NEXT_BIT_POSITION <= CURRENT_BIT_POSITION + 1;</pre>
```

The first statement assigns the current serial input bit to a particular bit of the parallel output. The second statement increments the next bit position to be assigned.

SYNCH registers and updates the stored values previously described. Each registered signal has two parts, NEXT\_... and CURRENT\_...:

#### NEXT ...

Signals hold values computed by the NEXT\_ST process.

### CURRENT ...

Signals hold the values driven by the SYNCH process. The CURRENT\_... signals hold the values of the NEXT\_... signals as of the last clock edge.

Example A-12 shows a VHDL description of the converter.

### Example A-12 Serial-to-Parallel Converter—Counting Bits

```
-- Serial-to-Parallel Converter, counting bits
package TYPES is
  -- Declares types used in the rest of the design
  type STATE_TYPE is (WAIT_FOR_START,
                      READ BITS,
                      PARITY_ERROR_DETECTED,
                      ALLOW_READ);
  constant PARALLEL_BIT_COUNT: INTEGER := 8;
  subtype PARALLEL_RANGE is INTEGER
      range 0 to (PARALLEL_BIT_COUNT-1);
  subtype PARALLEL_TYPE is BIT_VECTOR(PARALLEL_RANGE);
end TYPES;
use WORK.TYPES.ALL;
                        -- Use the TYPES package
entity SER_PAR is
                        -- Declare the interface
  port(SERIAL_IN, CLOCK, RESET: in BIT;
       PARALLEL_OUT: out PARALLEL_TYPE;
       PARITY_ERROR, READ_ENABLE: out BIT);
end;
architecture BEHAVIOR of SER_PAR is
  -- Signals for stored values
  signal CURRENT_STATE, NEXT_STATE: STATE_TYPE;
  signal CURRENT_PARITY, NEXT_PARITY: BIT;
  signal CURRENT_BIT_POSITION, NEXT_BIT_POSITION:
      INTEGER range PARALLEL_BIT_COUNT downto 0;
  signal CURRENT_PARALLEL_OUT, NEXT_PARALLEL_OUT:
      PARALLEL_TYPE;
begin
NEXT_ST: process(SERIAL_IN, CURRENT_STATE, RESET,
                 CURRENT_BIT_POSITION, CURRENT_PARITY,
                 CURRENT_PARALLEL_OUT)
  -- This process computes all outputs, the next
  -- state, and the next value of all stored values
  begin
   PARITY_ERROR <= '0'; -- Default values for all
   READ_ENABLE <= '0'; -- outputs and stored values</pre>
   NEXT_STATE <= CURRENT_STATE;</pre>
   NEXT_BIT_POSITION <= 0;</pre>
   NEXT_PARITY <= '0';</pre>
   NEXT_PARALLEL_OUT <= CURRENT_PARALLEL_OUT;</pre>
    if (RESET = '1') then
                                -- Synchronous reset
      NEXT_STATE <= WAIT_FOR_START;</pre>
    else
      case CURRENT_STATE is
                             -- State processing
        when WAIT_FOR_START =>
```

```
if (SERIAL_IN = '1') then
            NEXT_STATE <= READ_BITS;</pre>
            NEXT_PARALLEL_OUT <=
                PARALLEL_TYPE'(others=>'0');
          end if;
        when READ_BITS =>
          if (CURRENT_BIT_POSITION =
              PARALLEL_BIT_COUNT) then
            if (CURRENT_PARITY = SERIAL_IN) then
              NEXT_STATE <= ALLOW_READ;</pre>
              READ_ENABLE <= '1';</pre>
            else
              NEXT_STATE <= PARITY_ERROR_DETECTED;</pre>
            end if;
          else
            NEXT_PARALLEL_OUT(CURRENT_BIT_POSITION) <=</pre>
               SERIAL_IN;
            NEXT BIT POSITION <=
                CURRENT_BIT_POSITION + 1;
            NEXT_PARITY <= CURRENT_PARITY xor</pre>
                            SERIAL_IN;
          end if;
        when PARITY_ERROR_DETECTED =>
          PARITY_ERROR <= '1';
        when ALLOW_READ =>
          NEXT_STATE <= WAIT_FOR_START;</pre>
      end case;
    end if;
  end process;
  SYNCH: process
    -- This process remembers the stored values
         across clock cycles
  begin
    wait until CLOCK'event and CLOCK = '1';
    CURRENT_STATE <= NEXT_STATE;
    CURRENT_BIT_POSITION <= NEXT_BIT_POSITION;
    CURRENT_PARITY <= NEXT_PARITY;
    CURRENT_PARALLEL_OUT <= NEXT_PARALLEL_OUT;
  end process;
  PARALLEL_OUT <= CURRENT_PARALLEL_OUT;
end BEHAVIOR;
```

# **Serial-to-Parallel Converter—Shifting Bits**

This example describes another implementation of the serial-to-parallel converter in the last example. This design performs the same function as the previous one but uses a different algorithm to do the conversion.

The previous implementation used a counter to indicate the bit of the output that was set when a new serial bit was read. In this implementation, the serial bits are shifted into place. Before the conversion occurs, a '1' is placed in the least-significant bit position. When that '1' is shifted out of the most significant position (position 0), the signal NEXT\_HIGH\_BIT is set to '1' and the conversion is complete.

Example A-13 shows the listing of the second implementation. The differences are highlighted in bold. The differences relate to the removal of the ...\_BIT\_POSITION signals, the addition of ...\_HIGH\_BIT signals, and the change in the way NEXT\_PARALLEL\_OUT is computed.

### Example A-13 Serial-to-Parallel Converter—Shifting Bits

```
package TYPES is
 -- Declares types used in the rest of the design
 type STATE_TYPE is (WAIT_FOR_START,
                     READ_BITS,
                     PARITY_ERROR_DETECTED,
                     ALLOW_READ);
 constant PARALLEL_BIT_COUNT: INTEGER := 8;
 subtype PARALLEL RANGE is INTEGER
     range 0 to (PARALLEL_BIT_COUNT-1);
 subtype PARALLEL_TYPE is BIT_VECTOR(PARALLEL_RANGE);
end TYPES;
use WORK.TYPES.ALL; -- Use the TYPES package
entity SER_PAR is
                    -- Declare the interface
 port(SERIAL_IN, CLOCK, RESET: in BIT;
      PARALLEL_OUT: out PARALLEL_TYPE;
      PARITY_ERROR, READ_ENABLE: out BIT);
end:
architecture BEHAVIOR of SER_PAR is
 -- Signals for stored values
 signal CURRENT_STATE, NEXT_STATE: STATE_TYPE;
 signal CURRENT_PARITY, NEXT_PARITY: BIT;
 signal CURRENT_HIGH_BIT, NEXT_HIGH_BIT: BIT;
 signal CURRENT_PARALLEL_OUT, NEXT_PARALLEL_OUT:
    PARALLEL_TYPE;
begin
NEXT_ST: process(SERIAL_IN, CURRENT_STATE, RESET,
                CURRENT_HIGH_BIT, CURRENT_PARITY,
                 CURRENT_PARALLEL_OUT)
 -- This process computes all outputs, the next
```

```
-- state, and the next value of all stored values
  begin
    PARITY_ERROR <= '0'; -- Default values for all
    READ_ENABLE <= '0'; -- outputs and stored values</pre>
    NEXT_STATE <= CURRENT_STATE;</pre>
   NEXT_HIGH_BIT <= '0';</pre>
   NEXT_PARITY <= '0';</pre>
   NEXT_PARALLEL_OUT <= PARALLEL_TYPE'(others=>'0');
    if(RESET = '1') then
                          -- Synchronous reset
      NEXT_STATE <= WAIT_FOR_START;</pre>
    else
      case CURRENT_STATE is -- State processing
        when WAIT_FOR_START =>
          if (SERIAL_IN = '1') then
            NEXT_STATE <= READ_BITS;</pre>
            NEXT_PARALLEL_OUT <=
               PARALLEL_TYPE'(others=>'0');
          end if;
        when READ_BITS =>
          if (CURRENT_HIGH_BIT = '1') then
            if (CURRENT_PARITY = SERIAL_IN) then
              NEXT_STATE <= ALLOW_READ;</pre>
              READ ENABLE <= '1';
            else
              NEXT_STATE <= PARITY_ERROR_DETECTED;</pre>
            end if;
          else
            NEXT HIGH BIT <= CURRENT PARALLEL OUT(0);
            NEXT_PARALLEL_OUT <=
                CURRENT_PARALLEL_OUT(
                    1 to PARALLEL_BIT_COUNT-1) &
                SERIAL_IN;
            NEXT_PARITY <= CURRENT_PARITY xor</pre>
                           SERIAL_IN;
          end if;
        when PARITY_ERROR_DETECTED =>
          PARITY_ERROR <= '1';
        when ALLOW_READ =>
          NEXT_STATE <= WAIT_FOR_START;</pre>
      end case;
    end if;
  end process;
  SYNCH: process
    -- This process remembers the stored values
    -- across clock cycles
    wait until CLOCK'event and CLOCK = '1';
    CURRENT_STATE <= NEXT_STATE;
    CURRENT_HIGH_BIT <= NEXT_HIGH_BIT;
    CURRENT_PARITY <= NEXT_PARITY;
    CURRENT_PARALLEL_OUT <= NEXT_PARALLEL_OUT;
  end process;
  PARALLEL_OUT <= CURRENT_PARALLEL_OUT;
end BEHAVIOR;
```

#### Note:

The synthesized schematic for the shifter implementation is much simpler than that of the previous count implementation in Example A-12 on page A-29. It is simpler because the shifter algorithm is inherently easier to implement.

With the count algorithm, each of the flip-flops holding the PARALLEL\_OUT bits needed logic that decoded the value stored in the BIT\_POSITION flip-flops to see when to route in the value of SERIAL\_IN. Also, the BIT\_POSITION flip-flops needed an incrementer to compute their next value.

In contrast, the shifter algorithm requires neither an incrementer nor flip-flops to hold BIT\_POSITION. Additionally, the logic in front of most PARALLEL\_OUT bits needs to read only the value of the previous flip-flop or '0'. The value depends on whether bits are currently being read. In the shifter algorithm, the SERIAL\_IN port needs to be connected only to the least significant bit (number 7) of the PARALLEL\_OUT flip-flops.

These two implementations illustrate the importance of designing efficient algorithms. Both work properly, but the shifter algorithm produces a faster, more area-efficient design.

### **Programmable Logic Arrays**

This example shows a way to build programmable logic arrays (PLAs) in VHDL. The PLA function uses an input lookup vector as an index into a constant PLA table and then returns the output vector specified by the PLA.

The PLA table is an array of PLA rows, where each row is an array of PLA elements. Each element is either a one, a zero, a minus, or a space ('1', '0', '-', or' '). The table is split between an input plane and an output plane. The input plane is specified by 0s, 1s, and minuses. The output plane is specified by 0s and 1s. The two planes' values are separated by a space.

In the PLA function, the output vector is first initialized to be all 0s. When the input vector matches an input plane in a row of the PLA table, the 1s in the output plane are assigned to the corresponding bits in the output vector. A match is determined as follows:

- If a 0 or 1 is in the input plane, the input vector must have the same value in the same position.
- If a minus is in the input plane, it matches any input vector value at that position.

The generic PLA table types and the PLA function are defined in a package named LOCAL. An entity PLA\_VHDL that uses LOCAL needs only to specify its PLA table as a constant, then call the PLA function.

The PLA function does not explicitly depend on the size of the PLA. To change the size of the PLA, change the initialization of the TABLE constant and the initialization of the constants INPUT\_COUNT, OUTPUT\_COUNT, and ROW\_COUNT. In Example A-14, these constants are initialized to a PLA equivalent to the ROM shown previously (Example A-1 on page A-3). Accordingly, the synthesized schematic is the same as that of the ROM, with one difference: in Example A-1, the DATA output port range is 1 to 5; in Example A-14, the OUT VECTOR output port range is 4 down to 0.

Example A-14 shows the capabilities of VHDL. It is more efficient to define the PLA directly by using the PLA input format. See the *Design Compiler Reference Manual: Optimization and Timing Analysis* for more information about the PLA input format.

### Example A-14 Programmable Logic Array

```
package LOCAL is
  constant INPUT_COUNT: INTEGER := 3;
  constant OUTPUT_COUNT: INTEGER := 5;
  constant ROW COUNT: INTEGER := 6;
  constant ROW_SIZE: INTEGER := INPUT_COUNT +
                                OUTPUT_COUNT + 1;
  type PLA_ELEMENT is ('1', '0', '-', '');
  type PLA_VECTOR is
      array (INTEGER range <>) of PLA_ELEMENT;
  subtype PLA ROW is
      PLA_VECTOR(ROW_SIZE - 1 downto 0);
  subtype PLA_OUTPUT is
     PLA_VECTOR(OUTPUT_COUNT - 1 downto 0);
  type PLA_TABLE is
      array(ROW_COUNT - 1 downto 0) of PLA_ROW;
  function PLA(IN_VECTOR: BIT_VECTOR;
               TABLE: PLA_TABLE)
      return BIT_VECTOR;
end LOCAL;
package body LOCAL is
  function PLA(IN_VECTOR: BIT_VECTOR;
               TABLE: PLA_TABLE)
      return BIT_VECTOR is
    subtype RESULT TYPE is
        BIT_VECTOR(OUTPUT_COUNT - 1 downto 0);
    variable RESULT: RESULT_TYPE;
    variable ROW: PLA_ROW;
    variable MATCH: BOOLEAN;
    variable IN_POS: INTEGER;
  begin
    RESULT := RESULT_TYPE'(others => BIT'( '0'));
    for I in TABLE'range loop
```

```
ROW := TABLE(I);
     MATCH := TRUE;
      IN_POS := IN_VECTOR'left;
      -- Check for match in input plane
      for J in ROW_SIZE - 1 downto OUTPUT_COUNT loop
        if(ROW(J) = PLA\_ELEMENT'('1')) then
          MATCH := MATCH and
                   (IN_VECTOR(IN_POS) = BIT'('1'));
        elsif(ROW(J) = PLA_ELEMENT'('0')) then
          MATCH := MATCH and
                   (IN VECTOR(IN POS) = BIT'('0'));
          null;
                   -- Must be minus ("don't care")
        end if;
        IN_POS := IN_POS - 1;
      end loop;
      -- Set output plane
      if(MATCH) then
        for J in RESULT'range loop
          if(ROW(J) = PLA\_ELEMENT'('1')) then
            RESULT(J) := BIT'('1');
          end if;
        end loop;
      end if;
    end loop;
    return(RESULT);
end LOCAL;
use WORK.LOCAL.all;
entity PLA_VHDL is
 port(IN VECTOR: BIT VECTOR(2 downto 0);
       OUT_VECTOR: out BIT_VECTOR(4 downto 0));
end;
architecture BEHAVIOR of PLA_VHDL is
  constant TABLE: PLA_TABLE := PLA_TABLE'(
       PLA_ROW'("--- 10000"),
       PLA_ROW'("-1- 01000"),
       PLA_ROW'("0-0 00101"),
       PLA_ROW'("-1- 00101"),
       PLA_ROW'("1-1 00101"),
       PLA_ROW'("-1- 00010"));
begin
  OUT_VECTOR <= PLA(IN_VECTOR, TABLE);
end BEHAVIOR;
```



# В

# **Predefined Libraries**

This appendix describes the following packages that are included in a Presto VHDL installation:

- std\_logic\_1164
- std\_logic\_arith
- numeric\_std
- std\_logic\_misc
- Standard Package
- Synopsys Package—ATTRIBUTES

## std\_logic\_1164

The std\_logic\_1164 package is typically installed in the \$SYNOPSYS/packages/IEEE/src/std\_logic\_1164.vhd subdirectory of the Synopsys root directory. The std\_logic\_1164.vhd file has been updated with Synopsys synthesis directives, such as the built\_in pragma described below. Presto VHDL automatically uses the built\_in pragmas to improve performance. You can also write your own built\_in pragmas.

## built\_in Pragmas

The Synopsys IEEE std\_logic\_1164 package contains the following built\_in functions that enable Presto VHDL to quickly and easily interpret your code:

- SYN AND
- SYN\_OR
- SYN NAND
- SYN\_NOR
- SYN XOR
- SYN XNOR
- SYN NOT
- SYN BUF

These functions are automatically enabled by Presto VHDL for the respective operators in your code and you do not have to use these in your code. If you want to create your own built\_in functions, label them with the <code>built\_in</code> pragma. When you use a <code>built\_in</code> pragma, Presto VHDL parses but ignores the body of the function and directly substitutes the appropriate logic for the function.

Create a built\_in function by using the built\_in pragma as shown in Example B-1. Presto VHDL interprets a comment as a directive if the first word of the comment is pragma. Example B-1 shows the XOR built\_in function.

## Example B-1 XOR built\_in Function

```
function "XOR" (L, R: STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR is
   -- pragma built_in SYN_XOR
   begin
      if (L = '1') xor (R = '1') then
           return '1';
      else
           return '0';
      end if;
end "XOR";
```

## Example B-2 shows the SYN\_AND built\_in function.

## Example B-2 SYN\_AND built\_in Function

```
function "AND" (L, R: STD LOGIC VECTOR) return
STD LOGIC VECTOR is
  -- pragma built_in SYN_AND
    variable MY_L: STD_LOGIC_VECTOR (L'length-1 downto 0);
    variable MY_R: STD_LOGIC_VECTOR (L'length-1 downto 0);
    variable RESULT: STD_LOGIC_VECTOR (L'length-1 downto 0);
   assert L'length = R'length;
   MY_L := L;
   MY_R := R;
   for i in RESULT'range loop
        if (MY_L(i) = '1') and (MY_R(i) = '1') then
            RESULT(i) := '1';
        else
            RESULT(i) := '0';
        end if;
    end loop;
    return RESULT;
end "AND";
```

## Example B-3 shows the SYN\_NOT built\_in function.

## Example B-3 SYN\_NOT built\_in Function

```
function "NOT" (L: STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR is
  -- pragma built_in SYN_NOT
     variable MY_L: STD_LOGIC_VECTOR (L'length-1 downto 0);
     variable RESULT: STD_LOGIC_VECTOR (L'length-1 downto 0);
begin
   MY_L := L;
    for i in result'range loop
        if (MY_L(i) = '0' \text{ or } MY_L(i) = 'L') then
            RESULT(i) := '1';
        elsif (MY_L(i) = '1' \text{ or } MY_L(i) = 'H') then
            RESULT(i) := '0';
        else
            RESULT(i) := 'X';
        end if;
    end loop:
    return RESULT;
end "NOT";
```

Example B-4 shows the SYN\_FEED\_THRU built\_in function which performs type conversion between unrelated types. The synthesized logic from SYN\_FEED\_THRU wires the single input of a function to the return value.

## Example B-4 SYN\_FEED\_THRU built\_in Function

```
type COLOR is (RED, GREEN, BLUE);
attribute ENUM_ENCODING : STRING;
attribute ENUM_ENCODING of COLOR : type is "01 10 11";
...

function COLOR_TO_BV (L: COLOR) return BIT_VECTOR is
    -- pragma built_in SYN_FEED_THRU
begin
    case L is
        when RED => return "01";
        when GREEN => return "10";
        when BLUE => return "11";
    end case;
end COLOR_TO_BV;
```

## std\_logic\_arith

This section contains the following subsections:

- std\_logic\_arith Package Overview
- Modifying the std\_logic\_arith Package
- std\_logic\_arith Data Types
- UNSIGNED
- SIGNED
- Conversion Functions
- Arithmetic Functions
- Comparison Functions
- Shift Functions
- Multiplication Using Shifts

## std\_logic\_arith Package Overview

The std\_logic\_arith package is typically installed in the \$SYNOPSYS/packages/IEEE/src/std\_logic\_arith.vhd subdirectory of the Synopsys root directory. To use this package in a VHDL source file, include the following lines at the beginning of the source file:

```
library IEEE;
use IEEE.std_logic_arith.all;
```

The package also defines two major data types of its own: UNSIGNED and SIGNED (see "std\_logic\_arith Data Types" on page B-7 for details). The std\_logic\_arith package is legal VHDL; you can use it for both synthesis and simulation.

You can configure the std\_logic\_arith package to work on any array of single-bit types. You encode single-bit types in 1 bit with the ENUM\_ENCODING attribute.

You can make the vector type (for example, std\_logic\_vector) synonymous with either SIGNED or UNSIGNED. This way, if you plan to use mostly UNSIGNED numbers, you do not need to convert your vector type to call UNSIGNED functions. The disadvantage of making your vector type synonymous with either UNSIGNED or SIGNED is that it causes redefinition of the standard VHDL comparison functions (=, =, <, >, <=, >=).

Table B-1 shows that the standard comparison functions for BIT\_VECTOR do not match the SIGNED and UNSIGNED functions.

Table B-1 UNSIGNED, SIGNED, and BIT\_VECTOR Comparison Functions

| ARG1  | ор | ARG2   | UNSIGNED | SIGNED | BIT_VECTOR |
|-------|----|--------|----------|--------|------------|
| "000" | =  | "000"  | true     | true   | true       |
| "00"  | =  | "000"  | true     | true   | false      |
| "100" | =  | "0100" | true     | false  | false      |
| "000" | <  | "000"  | false    | false  | false      |
| "00"  | <  | "000"  | false    | false  | true       |
| "100" | <  | "0100" | false    | true   | false      |

## Modifying the std\_logic\_arith Package

The std\_logic\_arith package is written in standard VHDL. You can modify or add to it. When you change the content, you must reanalyze the package.

For example, to convert a vector of multivalued logic to an INTEGER, you can write the function shown in Example B-5. This MVL\_TO\_INTEGER function returns the integer value corresponding to the vector when the vector is interpreted as an unsigned (natural) number. If unknown values are in the vector, the return value is -1.

## Example B-5 New Function Based on a std\_logic\_arith Package Function

```
library IEEE;
use IEEE.std logic 1164.all;
function MVL_TO_INTEGER(ARG : MVL_VECTOR)
  return INTEGER is
  -- pragma built_in SYN_FEED_THRU
  variable uns: UNSIGNED (ARG'range);
begin
    for i in ARG'range loop
        case ARG(i) is
            when '0' | 'L' => uns(i) := '0';
            when '1' | 'H' => uns(i) := '1';
            when others => return -1;
        end case;
    end loop;
    return CONV_INTEGER(uns);
end:
```

Note the use of the CONV\_INTEGER function in Example B-5.

Design Compiler performs almost all synthesis directly from the VHDL descriptions. However, several functions are hard-wired for efficiency. They can be identified by the following comment in their declarations:

```
-- pragma built_in
```

This statement marks functions as special, causing the body of the function to be ignored. Modifying the body does not change the synthesized logic unless you remove the built\_in comment. If you want new functionality, write it by using the built\_in function; this is more efficient than removing the built\_in function and modifying the body of the function.

## std\_logic\_arith Data Types

The std\_logic\_arith package defines two data types: UNSIGNED and SIGNED.

```
type UNSIGNED is array (natural range <>) of std_logic;
type SIGNED is array (natural range <>) of std_logic;
```

These data types are similar to the predefined VHDL type BIT\_VECTOR, but the std\_logic\_arith package defines the interpretation of variables and signals of these types as numeric values.

## **UNSIGNED**

The UNSIGNED data type represents an unsigned numeric value. Presto VHDL interprets the number as a binary representation, with the farthest-left bit being most significant. For example, the decimal number 8 can be represented as

```
UNSIGNED'("1000")
```

When you declare variables or signals of type UNSIGNED, a larger vector holds a larger number. A 4-bit variable holds values up to decimal 15, an 8-bit variable holds values up to 255, and so on. By definition, negative numbers cannot be represented in an UNSIGNED variable. Zero is the smallest value that can be represented.

Example B-6 illustrates some UNSIGNED declarations. The most significant bit is the farthest-left array bound, rather than the high- or low-range value.

## Example B-6 UNSIGNED Declarations

```
variable VAR: UNSIGNED (1 to 10);
  -- 10-bit number
  -- VAR(VAR'left) = VAR(1) is the most significant bit
signal SIG: UNSIGNED (5 downto 0);
  -- 6-bit number
  -- SIG(SIG'left) = SIG(5) is the most significant bit
```

## SIGNED

The SIGNED data type represents a signed numeric value. Presto VHDL interprets the number as a 2's-complement binary representation, with the farthest-left bit as the sign bit. For example, you can represent decimal 5 and –5 as

```
SIGNED'("0101") -- represents +5
SIGNED'("1011") -- represents -5
```

When you declare SIGNED variables or signals, a larger vector holds a larger number. A 4-bit variable holds values from –8 to 7; an 8-bit variable holds values from –128 to 127. A SIGNED value cannot hold as large a value as an UNSIGNED value with the same bit-width.

Example B-7 shows some SIGNED declarations. The sign bit is the farthest-left bit, rather than the highest or lowest.

## Example B-7 SIGNED Declarations

```
variable S_VAR: SIGNED (1 to 10);
  -- 10-bit number
  -- S_VAR(S_VAR'left) = S_VAR(1) is the sign bit
signal S_SIG: SIGNED (5 downto 0);
  -- 6-bit number
  -- S_SIG(S_SIG'left) = S_SIG(5) is the sign bit
```

## **Conversion Functions**

The std\_logic\_arith package provides three sets of functions to convert values between its UNSIGNED and SIGNED types and the predefined type INTEGER. This package also provides the std\_logic\_vector. Example B-8 shows the declarations of these conversion functions, with BIT and BIT\_VECTOR types.

#### Example B-8 Conversion Functions

```
subtype SMALL INT is INTEGER range 0 to 1;
function CONV_INTEGER(ARG: INTEGER) return INTEGER;
function CONV_INTEGER(ARG: UNSIGNED) return INTEGER;
function CONV_INTEGER(ARG: SIGNED) return INTEGER;
function CONV_INTEGER(ARG: STD_ULOGIC) return SMALL_INT;
function CONV UNSIGNED (ARG: INTEGER;
                       SIZE: INTEGER) return UNSIGNED;
function CONV UNSIGNED (ARG: UNSIGNED;
                       SIZE: INTEGER) return UNSIGNED;
function CONV_UNSIGNED(ARG: SIGNED;
                       SIZE: INTEGER) return UNSIGNED;
function CONV UNSIGNED (ARG: STD ULOGIC;
                       SIZE: INTEGER) return UNSIGNED;
function CONV_SIGNED(ARG: INTEGER;
                     SIZE: INTEGER)
                                      return SIGNED;
function CONV SIGNED (ARG: UNSIGNED;
                                      return SIGNED;
                     SIZE: INTEGER)
function CONV_SIGNED(ARG: SIGNED;
                     SIZE: INTEGER)
                                      return SIGNED;
function CONV_SIGNED(ARG: STD_ULOGIC;
                     SIZE: INTEGER)
                                      return SIGNED;
function CONV STD LOGIC VECTOR (ARG: INTEGER;
                                      return STD_LOGIC_VECTOR;
                     SIZE: INTEGER)
function CONV STD LOGIC VECTOR (ARG: UNSIGNED;
                     SIZE: INTEGER) return STD_LOGIC_VECTOR;
function CONV_STD_LOGIC_VECTOR(ARG: SIGNED;
                     SIZE: INTEGER) return STD LOGIC VECTOR;
```

There are four versions of each conversion function. The VHDL operator overloading mechanism determines the correct version from the function call's argument types.

The CONV\_INTEGER functions convert an argument of type INTEGER, UNSIGNED, SIGNED, or STD\_ULOGIC to an INTEGER return value. The CONV\_UNSIGNED and CONV\_SIGNED functions convert an argument of type INTEGER, UNSIGNED, SIGNED, or STD\_ULOGIC to an UNSIGNED or SIGNED return value whose bit width is SIZE.

The CONV\_INTEGER functions have a limitation on the size of operands. VHDL defines INTEGER values as being between –2147483647 and 2147483647. This range corresponds to a 31-bit UNSIGNED value or a 32-bit SIGNED value. You cannot convert an argument outside this range to an INTEGER.

The CONV\_UNSIGNED and CONV\_SIGNED functions each require two operands. The first operand is the value converted. The second operand is an INTEGER that specifies the expected size of the converted result. For example, the following function call returns a 10-bit UNSIGNED value representing the value in sig.

```
ten_unsigned_bits := CONV_UNSIGNED(sig, 10);
```

If the value passed to CONV\_UNSIGNED or CONV\_SIGNED is smaller than the expected bit-width (such as representing the value 2 in a 24-bit number), the value is bit-extended appropriately. Presto VHDL places 0s in the more significant (left) bits for an UNSIGNED return value, and it uses sign extension for a SIGNED return value.

You can use the conversion functions to extend a number's bit-width even if conversion is not required. For example,

```
CONV_SIGNED(SIGNED'("110"), 8) -> "11111110"
```

An UNSIGNED or SIGNED return value is truncated when its bit-width is too small to hold the ARG value. For example,

```
CONV_SIGNED(UNSIGNED'("1101010"), 3) -> "010"
```

## **Arithmetic Functions**

The std\_logic\_arith package provides arithmetic functions for use with combinations of the Synopsys UNSIGNED and SIGNED data types and the predefined types STD\_ULOGIC and INTEGER. These functions produce adders and subtracters.

There are two sets of arithmetic functions: binary functions having two arguments, such as A+B or A\*B, and unary functions having one argument, such as –A. Example B-9 and Example B-10 show the declarations for these functions.

#### Example B-9 Binary Arithmetic Functions

```
function "+"(L: UNSIGNED; R: UNSIGNED) return UNSIGNED;
function "+"(L: SIGNED; R: SIGNED) return SIGNED;
function "+"(L: UNSIGNED; R: SIGNED) return SIGNED;
function "+"(L: SIGNED; R: UNSIGNED) return SIGNED;
function "+"(L: UNSIGNED; R: INTEGER) return UNSIGNED;
function "+"(L: INTEGER; R: UNSIGNED) return UNSIGNED;
function "+"(L: SIGNED; R: INTEGER) return SIGNED;
function "+"(L: INTEGER; R: SIGNED) return SIGNED;
function "+"(L: UNSIGNED; R: STD_ULOGIC) return UNSIGNED;
function "+"(L: STD_ULOGIC; R: UNSIGNED) return UNSIGNED;
function "+"(L: SIGNED; R: STD_ULOGIC) return SIGNED;
function "+"(L: STD_ULOGIC; R: SIGNED) return SIGNED;
function "+"(L: UNSIGNED; R: UNSIGNED) return STD_LOGIC_VECTOR;
function "+"(L: SIGNED; R: SIGNED) return STD_LOGIC_VECTOR;
function "+"(L: UNSIGNED; R: SIGNED) return STD_LOGIC_VECTOR;
function "+"(L: SIGNED; R: UNSIGNED) return STD_LOGIC_VECTOR;
function "+"(L: UNSIGNED; R: INTEGER) return STD_LOGIC_VECTOR;
function "+"(L: INTEGER; R: UNSIGNED) return STD_LOGIC_VECTOR;
function "+"(L: SIGNED; R: INTEGER) return STD_LOGIC_VECTOR;
function "+"(L: INTEGER; R: SIGNED) return STD_LOGIC_VECTOR;
function "+"(L: UNSIGNED; R: STD_ULOGIC) return STD_LOGIC_VECTOR;
function "+"(L: STD_ULOGIC; R: UNSIGNED) return STD_LOGIC_VECTOR;
function "+"(L: SIGNED; R: STD_ULOGIC) return STD_LOGIC_VECTOR;
function "+"(L: STD_ULOGIC; R: SIGNED) return STD_LOGIC_VECTOR;
function "-"(L: UNSIGNED; R: UNSIGNED) return UNSIGNED;
function "-"(L: SIGNED; R: SIGNED) return SIGNED;
function "-"(L: UNSIGNED; R: SIGNED) return SIGNED;
function "-"(L: SIGNED; R: UNSIGNED) return SIGNED;
function "-"(L: UNSIGNED; R: INTEGER) return UNSIGNED;
function "-"(L: INTEGER; R: UNSIGNED) return UNSIGNED;
function "-"(L: SIGNED; R: INTEGER) return SIGNED;
function "-"(L: INTEGER; R: SIGNED) return SIGNED;
function "-"(L: UNSIGNED; R: STD_ULOGIC) return UNSIGNED;
function "-"(L: STD_ULOGIC; R: UNSIGNED) return UNSIGNED;
function "-"(L: SIGNED; R: STD_ULOGIC) return SIGNED;
function "-"(L: STD ULOGIC; R: SIGNED)
                                          return SIGNED;
function "-"(L: UNSIGNED; R: UNSIGNED) return STD_LOGIC_VECTOR;
function "-"(L: SIGNED; R: SIGNED) return STD_LOGIC_VECTOR;
function "-"(L: UNSIGNED; R: SIGNED) return STD_LOGIC_VECTOR;
function "-"(L: SIGNED; R: UNSIGNED) return STD_LOGIC_VECTOR;
function "-"(L: UNSIGNED; R: INTEGER) return STD_LOGIC_VECTOR;
function "-"(L: INTEGER; R: UNSIGNED) return STD_LOGIC_VECTOR;
function "-"(L: SIGNED; R: INTEGER) return STD_LOGIC_VECTOR;
function "-"(L: INTEGER; R: SIGNED) return STD_LOGIC_VECTOR;
function "-"(L: UNSIGNED; R: STD_ULOGIC) return STD_LOGIC_VECTOR;
function "-"(L: STD ULOGIC; R: UNSIGNED) return STD LOGIC VECTOR;
function "-"(L: SIGNED; R: STD_ULOGIC) return STD_LOGIC_VECTOR;
function "-"(L: STD_ULOGIC; R: SIGNED) return STD_LOGIC_VECTOR;
function "*"(L: UNSIGNED; R: UNSIGNED) return UNSIGNED;
function "*"(L: SIGNED; R: SIGNED) return SIGNED;
function "*"(L: SIGNED; R: UNSIGNED) return SIGNED;
function "*"(L: UNSIGNED; R: SIGNED) return SIGNED;
```

## Example B-10 Unary Arithmetic Functions

```
function "+"(L: UNSIGNED) return UNSIGNED;
function "+"(L: SIGNED) return SIGNED;
function "-"(L: SIGNED) return SIGNED;
function "ABS"(L: SIGNED) return SIGNED;
```

The binary and unary arithmetic functions in Example B-9 and Example B-10 determine the width of their return values, as follows:

- 1. When only one UNSIGNED or SIGNED argument is present, the width of the return value is the same as that argument's.
- 2. When both arguments are either UNSIGNED or SIGNED, the width of the return value is the larger of the two argument widths. An exception is that when an UNSIGNED number is added to or subtracted from a SIGNED number that is the same size or smaller, the return value is a SIGNED number 1 bit wider than the UNSIGNED argument. This size guarantees that the return value is large enough to hold any (positive) value of the UNSIGNED argument.

Table B-2 illustrates the number of bits returned by addition (+) and subtraction (-).

```
signal U4: UNSIGNED (3 downto 0);
signal U8: UNSIGNED (7 downto 0);
signal S4: SIGNED (3 downto 0);
signal S8: SIGNED (7 downto 0);
```

Table B-2 Number of Bits Returned by Addition and Subtraction

| + or - | U4 | U8 | S4 | S8 |
|--------|----|----|----|----|
| U4     | 4  | 8  | 5  | 8  |
| U8     | 8  | 8  | 9  | 9  |
| S4     | 5  | 9  | 4  | 8  |
| S8     | 8  | 9  | 8  | 8  |

In some circumstances, you might need to obtain a carry-out bit from the addition or subtraction operation. To do this, extend the larger operand by 1 bit. The high bit of the return value is the carry, as illustrated in Example B-11.

## Example B-11 Using the Carry-Out Bit

```
process
   variable a, b, sum: UNSIGNED (7 downto 0);
   variable temp: UNSIGNED (8 downto 0);
   variable carry: BIT;
begin
   temp := CONV_UNSIGNED(a,9) + b;
   sum := temp(7 downto 0);
   carry := temp(8);
end process;
```

## **Comparison Functions**

The std\_logic\_arith package provides functions for comparing UNSIGNED and SIGNED data types with each other and with the predefined type INTEGER. Presto VHDL compares the numeric values of the arguments, returning a BOOLEAN value. For example, the following expression evaluates true.

```
UNSIGNED'("001") > SIGNED'("111")
```

The std\_logic\_arith comparison functions are similar to the built-in VHDL comparison functions. The only difference is that the std\_logic\_arith functions accommodate signed numbers and varying bit-widths. The predefined VHDL comparison functions perform bitwise comparisons and do not have the correct semantics for comparing numeric values (see "Ordering of Enumerated Types Using the ENUM\_ENCODING attribute" on page 2-45).

These functions produce comparators. The function declarations are listed in two groups: ordering functions ("<", "<=", ">", ">="), shown in Example B-12, and equality functions ("=", "/="), shown in Example B-13.

## Example B-12 Ordering Functions

```
function "<"(L: UNSIGNED; R: UNSIGNED) return BOOLEAN;</pre>
  function "<"(L: SIGNED; R: SIGNED) return BOOLEAN;
function "<"(L: UNSIGNED; R: SIGNED) return BOOLEAN; function "<"(L: SIGNED; R: UNSIGNED) return BOOLEAN; function "<"(L: UNSIGNED; R: INTEGER) return BOOLEAN; function "<"(L: INTEGER; R: UNSIGNED) return BOOLEAN; function "<"(L: SIGNED; R: INTEGER) return BOOLEAN; function "<"(L: SIGNED; R: INTEGER) return BOOLEAN; function "<"(L: INTEGER; R: SIGNED) return BOOLEAN;
function "<="(L: UNSIGNED; R: UNSIGNED) return BOOLEAN;
function "<="(L: SIGNED; R: SIGNED) return BOOLEAN;
function "<="(L: UNSIGNED; R: SIGNED) return BOOLEAN;
function "<="(L: SIGNED; R: UNSIGNED) return BOOLEAN;
function "<="(L: UNSIGNED; R: UNSIGNED) return BOOLEAN;
function "<="(L: UNSIGNED; R: INTEGER) return BOOLEAN;
function "<="(L: INTEGER; R: UNSIGNED) return BOOLEAN;
function "<="(L: SIGNED; R: INTEGER) return BOOLEAN;
function "<="(L: SIGNED; R: SIGNED) return BOOLEAN;</pre>
 function ">"(L: UNSIGNED; R: UNSIGNED) return BOOLEAN;
 function ">"(L: SIGNED; R: SIGNED) return BOOLEAN;
function ">"(L: SIGNED; R: SIGNED) return BOOLEAN; function ">"(L: UNSIGNED; R: SIGNED) return BOOLEAN; function ">"(L: SIGNED; R: UNSIGNED) return BOOLEAN; function ">"(L: UNSIGNED; R: INTEGER) return BOOLEAN; function ">"(L: INTEGER; R: UNSIGNED) return BOOLEAN; function ">"(L: SIGNED; R: INTEGER) return BOOLEAN; function ">"(L: SIGNED; R: INTEGER) return BOOLEAN; function ">"(L: INTEGER; R: SIGNED) return BOOLEAN;
function ">="(L: UNSIGNED; R: UNSIGNED) return BOOLEAN;
function ">="(L: SIGNED; R: SIGNED) return BOOLEAN;
function ">="(L: UNSIGNED; R: SIGNED) return BOOLEAN;
function ">="(L: UNSIGNED; R: UNSIGNED) return BOOLEAN;
function ">="(L: SIGNED; R: UNSIGNED) return BOOLEAN;
function ">="(L: UNSIGNED; R: INTEGER) return BOOLEAN;
function ">="(L: INTEGER; R: UNSIGNED) return BOOLEAN;
function ">="(L: SIGNED; R: INTEGER) return BOOLEAN;
function ">="(L: SIGNED; R: SIGNED) return BOOLEAN;
```

#### Example B-13 Equality Functions

```
function "="(L: UNSIGNED; R: UNSIGNED) return BOOLEAN;
function "="(L: SIGNED; R: SIGNED) return BOOLEAN;
function "="(L: UNSIGNED; R: SIGNED) return BOOLEAN;
function "="(L: SIGNED; R: UNSIGNED) return BOOLEAN;
function "="(L: UNSIGNED; R: INTEGER) return BOOLEAN;
function "="(L: INTEGER; R: UNSIGNED) return BOOLEAN;
function "="(L: SIGNED; R: INTEGER) return BOOLEAN;
function "="(L: INTEGER; R: SIGNED) return BOOLEAN;
function "/="(L: UNSIGNED; R: UNSIGNED) return BOOLEAN;
function "/="(L: SIGNED; R: UNSIGNED) return BOOLEAN;
function "/="(L: SIGNED; R: UNSIGNED) return BOOLEAN;
function "/="(L: INTEGER; R: UNSIGNED) return BOOLEAN;
function "/="(L: SIGNED; R: INTEGER) return BOOLEAN;
function "/="(L: SIGNED; R: SIGNED) return BOOLEAN;
function "/="(L: SIGNED; R: SIGNE
```

## **Shift Functions**

The std\_logic\_arith package provides functions for shifting the bits in SIGNED and UNSIGNED numbers. These functions produce shifters. Example B-14 shows the shift function declarations. For a list of shift and rotate operators, see "Operators" on page C-7.

#### Example B-14 Shift Functions

The SHL function shifts the bits of its argument ARG left by COUNT bits. SHR shifts the bits of its argument ARG right by COUNT bits.

The SHL functions work the same for both UNSIGNED and SIGNED values of ARG, shifting in zero bits as necessary. The SHR functions treat UNSIGNED and SIGNED values differently. If ARG is an UNSIGNED number, vacated bits are filled with 0s; if ARG is a SIGNED number, the vacated bits are copied from the ARG sign bit.

Example B-15 shows some shift function calls and their return values.

## Example B-15 Shift Operations

```
variable U1, U2: UNSIGNED (7 downto 0);
variable S1, S2: SIGNED (7 downto 0);
variable COUNT: UNSIGNED (1 downto 0);
U1 := "01101011";
U2 := "11101011";
S1 := "01101011";
S2 := "11101011";
COUNT := CONV_UNSIGNED(ARG => 3, SIZE => 2);
SHL(U1, COUNT) = "01011000"
SHL(S1, COUNT) = "01011000"
SHL(U2, COUNT) = "01011000"
SHL(S2, COUNT) = "01011000"
SHR(U1, COUNT) = "00001101"
SHR(S1, COUNT) = "00001101"
SHR(U2, COUNT) = "00011101"
SHR(S2, COUNT) = "111111101"
```

## **Multiplication Using Shifts**

You can use shift operations for simple multiplication and division of UNSIGNED numbers if you are multiplying or dividing by a power of 2.

For example, to divide the following UNSIGNED variable U by 4, use this syntax:

```
variable U: UNSIGNED (7 downto 0) := "11010101";
variable quarter_U: UNSIGNED (5 downto 0);
quarter U := SHR(U, "01");
```

## numeric std

This section describes Presto VHDL support for the numeric\_std, the IEEE Standard VHDL Synthesis Package, which defines numeric types and arithmetic functions.

This section contains the following:

- Unsupported Constructs and Operators
- Using the numeric\_std Package
- numeric\_std Data Types

- Conversion Functions
- Resize Functions
- Arithmetic Functions
- Comparison Functions
- Defining Logical Operators Functions
- Shift and Rotate Functions
- Shift and Rotate Operators

#### Caution:

The numeric\_std package and the std\_logic\_arith package have overlapping operations. Use of these two packages simultaneously during analysis could cause type mismatches.

## **Unsupported Constructs and Operators**

Presto VHDL does not support the following numeric std package component:

TO\_01 function as a simulation construct

## Using the numeric\_std Package

The numeric\_std package is typically installed in the Synopsys root directory. Access it with the following statement in your VHDL code:

```
library IEEE;
use IEEE.numeric_std.all;
```

## numeric\_std Data Types

The numeric\_std package defines the following two data types in the same way that the std\_logic\_arith package does:

USIGNED

```
type UNSIGNED is array (NATURAL range <>) of STD_LOGIC;
See "UNSIGNED" on page B-7 for more information.
```

SIGNED

```
type SIGNED is array (NATURAL range <>) of STD_LOGIC;
See "SIGNED" on page B-7 for more information.
```

## **Conversion Functions**

The numeric\_std package provides functions to convert values between its UNSIGNED and SIGNED types. Table B-3 shows the declarations of these conversion functions.

Table B-3 numeric\_std Conversion Functions

| Parameters  |          |         |             |  |  |
|-------------|----------|---------|-------------|--|--|
| Operator    | Arg      | Size    | Return type |  |  |
| TO_INTEGER  | UNSIGNED |         | NATURAL     |  |  |
| TO_INTEGER  | SIGNED   |         | INTEGER     |  |  |
| TO_UNSIGNED | INTEGER  | NATURAL | UNSIGNED    |  |  |
| TO_SIGNED   | INTEGER  | NATURAL | SIGNED      |  |  |

TO\_INTEGER, TO\_SIGNED, and TO\_UNSIGNED are similar to CONV\_INTEGER, CONV\_SIGNED, and CONV\_UNSIGNED in std\_logic\_arith (see "Conversion Functions" on page B-8).

## **Resize Functions**

The resize function numeric\_std supports is shown in the declarations in Table B-4.

Table B-4 numeric\_std Resize Functions

| Parameters |         |         |             |  |  |
|------------|---------|---------|-------------|--|--|
| Operator   | Arg     | Size    | Return type |  |  |
| RESIZE     | NATURAL | NATURAL | SIGNED      |  |  |
| RESIZE     | NATURAL | NATURAL | UNSIGNED    |  |  |

## **Arithmetic Functions**

The numeric\_std package provides arithmetic functions for use with combinations of Synopsys UNSIGNED and SIGNED data types and the predefined types STD\_ULOGIC and INTEGER. These functions produce adders and subtracters.

There are two sets of arithmetic functions, which the numeric\_std package defines in the same way the std\_logic\_arith package does (see "Arithmetic Functions" on page B-9 for more information):

• Binary functions having two arguments, such as

A+B

A\*B

Table B-5 shows the declarations for these functions.

· Unary functions having one argument, such as

-A

abs A

Table B-6 shows the declarations for these functions.

Table B-5 numeric\_std Binary Arithmetic Functions

|          | Parameters |          |             |
|----------|------------|----------|-------------|
| Operator | L          | R        | Return type |
| "+"      | UNSIGNED   | UNSIGNED | UNSIGNED    |
| "+"      | SIGNED     | SIGNED   | SIGNED      |
| "+"      | UNSIGNED   | NATURAL  | UNSIGNED    |
| "+"      | NATURAL    | UNSIGNED | UNSIGNED    |
| "+"      | INTEGER    | SIGNED   | SIGNED      |
| "+"      | SIGNED     | INTEGER  | SIGNED      |
| "_"      | UNSIGNED   | UNSIGNED | UNSIGNED    |
| "_"      | SIGNED     | SIGNED   | SIGNED      |
| "_"      | UNSIGNED   | NATURAL  | UNSIGNED    |
| "_"      | NATURAL    | UNSIGNED | UNSIGNED    |
| "_"      | SIGNED     | INTEGER  | SIGNED      |
| п_п      | INTEGER    | SIGNED   | SIGNED      |
| II*II    | UNSIGNED   | UNSIGNED | UNSIGNED    |

Table B-5 numeric\_std Binary Arithmetic Functions (Continued)

|          | Parameters |          |             |
|----------|------------|----------|-------------|
| Operator | L          | R        | Return type |
| 11*11    | SIGNED     | SIGNED   | SIGNED      |
| 11*11    | UNSIGNED   | NATURAL  | UNSIGNED    |
| II*II    | NATURAL    | UNSIGNED | UNSIGNED    |
| II*II    | SIGNED     | INTEGER  | SIGNED      |
| П*П      | INTEGER    | SIGNED   | SIGNED      |

Table B-6 numeric\_std Unary Arithmetic Functions

| Operator | Arg    | Return Type |
|----------|--------|-------------|
| "abs"    | SIGNED | SIGNED      |
| "_"      | SIGNED | SIGNED      |

## **Comparison Functions**

The numeric\_std package provides functions to compare UNSIGNED and SIGNED data types with each other and with the predefined type INTEGER. Presto VHDL compares the numeric values of the arguments and returns a BOOLEAN value.

These functions produce comparators. The function declarations are listed in two groups:

- Ordering functions ("<", "<=", ">", ">="), shown in Table B-7
- Equality functions ("=", "/="), shown in Table B-8

Table B-7 numeric\_std Ordering Functions

| Parameters |          |          |             |  |
|------------|----------|----------|-------------|--|
| Operator   | L        | R        | Return type |  |
| ">"        | UNSIGNED | UNSIGNED | BOOLEAN     |  |
| ">"        | SIGNED   | SIGNED   | BOOLEAN     |  |
| ">"        | NATURAL  | UNSIGNED | BOOLEAN     |  |
| ">"        | INTEGER  | SIGNED   | BOOLEAN     |  |
| ">"        | UNSIGNED | NATURAL  | BOOLEAN     |  |
| ">"        | SIGNED   | INTEGER  | BOOLEAN     |  |
| "<"        | UNSIGNED | UNSIGNED | BOOLEAN     |  |
| "<"        | SIGNED   | SIGNED   | BOOLEAN     |  |
| "<"        | NATURAL  | UNSIGNED | BOOLEAN     |  |
| "<"        | INTEGER  | SIGNED   | BOOLEAN     |  |
| "<"        | UNSIGNED | NATURAL  | BOOLEAN     |  |
| "<"        | SIGNED   | INTEGER  | BOOLEAN     |  |
| "<="       | UNSIGNED | UNSIGNED | BOOLEAN     |  |
| "<="       | SIGNED   | SIGNED   | BOOLEAN     |  |
| "<="       | NATURAL  | UNSIGNED | BOOLEAN     |  |
| "<="       | INTEGER  | SIGNED   | BOOLEAN     |  |
| "<="       | UNSIGNED | NATURAL  | BOOLEAN     |  |
| "<="       | SIGNED   | INTEGER  | BOOLEAN     |  |
| ">="       | UNSIGNED | UNSIGNED | BOOLEAN     |  |
| ">="       | SIGNED   | SIGNED   | BOOLEAN     |  |

Table B-7 numeric\_std Ordering Functions (Continued)

| Parameters |          |          |             |  |  |
|------------|----------|----------|-------------|--|--|
| Operator   | L        | R        | Return type |  |  |
| ">="       | NATURAL  | UNSIGNED | BOOLEAN     |  |  |
| ">="       | INTEGER  | SIGNED   | BOOLEAN     |  |  |
| ">="       | UNSIGNED | NATURAL  | BOOLEAN     |  |  |
| ">="       | SIGNED   | INTEGER  | BOOLEAN     |  |  |

Table B-8 numeric\_std Equality Functions

| Parameters |          |          |             |  |
|------------|----------|----------|-------------|--|
| Operator   | L        | R        | Return type |  |
| "="        | UNSIGNED | UNSIGNED | BOOLEAN     |  |
| "="        | SIGNED   | SIGNED   | BOOLEAN     |  |
| "="        | NATURAL  | UNSIGNED | BOOLEAN     |  |
| "="        | INTEGER  | SIGNED   | BOOLEAN     |  |
| "="        | UNSIGNED | NATURAL  | BOOLEAN     |  |
| "="        | SIGNED   | INTEGER  | BOOLEAN     |  |
| "/="       | UNSIGNED | UNSIGNED | BOOLEAN     |  |
| "/="       | SIGNED   | SIGNED   | BOOLEAN     |  |
| "/="       | NATURAL  | UNSIGNED | BOOLEAN     |  |
| "/="       | INTEGER  | SIGNED   | BOOLEAN     |  |
| "/="       | UNSIGNED | NATURAL  | BOOLEAN     |  |
| "/="       | SIGNED   | INTEGER  | BOOLEAN     |  |

## **Defining Logical Operators Functions**

The numeric\_std package provides functions that define all of the logical operators: NOT, AND, OR, NAND, NOR, XOR, and XNOR. These functions work just like similar functions in std\_logic\_1164, except that they operate on SIGNED and UNSIGNED values rather than on STD\_LOGIC\_VECTOR values. Table B-9 shows these function declarations.

Table B-9 numeric\_std Logical Operators Functions

|          | Parameters |          |             |
|----------|------------|----------|-------------|
| Operator | L          | R        | Return type |
| "not"    | UNSIGNED   |          | UNSIGNED    |
| "and"    | UNSIGNED   | UNSIGNED | UNSIGNED    |
| "or"     | UNSIGNED   | UNSIGNED | UNSIGNED    |
| "nand"   | UNSIGNED   | UNSIGNED | UNSIGNED    |
| "nor"    | UNSIGNED   | UNSIGNED | UNSIGNED    |
| "xor"    | UNSIGNED   | UNSIGNED | UNSIGNED    |
| "xnor"   | UNSIGNED   | UNSIGNED | UNSIGNED    |
| "not"    | SIGNED     |          | SIGNED      |
| "and"    | SIGNED     | SIGNED   | SIGNED      |
| "or"     | SIGNED     | SIGNED   | SIGNED      |
| "nand"   | SIGNED     | SIGNED   | SIGNED      |
| "nor"    | SIGNED     | SIGNED   | SIGNED      |
| "xor"    | SIGNED     | SIGNED   | SIGNED      |
| "xnor"   | SIGNED     | SIGNED   | SIGNED      |

## **Shift and Rotate Functions**

The numeric\_std package provides functions for shifting the bits in UNSIGNED and SIGNED numbers. These functions produce shifters. Table B-10 shows the shift function declarations.

Table B-10 numeric\_std Shift and Rotate Functions

| Parameters   |          |         |             |  |
|--------------|----------|---------|-------------|--|
| Operator     | Arg      | Count   | Return type |  |
| SHIFT_LEFT   | UNSIGNED | NATURAL | UNSIGNED    |  |
| SHIFT_RIGHT  | UNSIGNED | NATURAL | UNSIGNED    |  |
| SHIFT_LEFT   | SIGNED   | NATURAL | SIGNED      |  |
| SHIFT_RIGHT  | SIGNED   | NATURAL | SIGNED      |  |
| ROTATE_LEFT  | UNSIGNED | NATURAL | UNSIGNED    |  |
| ROTATE_RIGHT | UNSIGNED | NATURAL | UNSIGNED    |  |
| ROTATE_LEFT  | SIGNED   | NATURAL | SIGNED      |  |
| ROTATE_RIGHT | SIGNED   | NATURAL | SIGNED      |  |

The SHIFT\_LEFT function shifts the bits of its argument ARG left by COUNT bits. SHIFT\_RIGHT shifts the bits of its argument ARG right by COUNT bits.

The SHIFT\_LEFT functions work the same for both UNSIGNED and SIGNED values of ARG, shifting in zero bits as necessary. The SHIFT\_RIGHT functions treat UNSIGNED and SIGNED values differently:

- If ARG is an UNSIGNED number, vacated bits are filled with 0s.
- If ARG is a SIGNED number, the vacated bits are copied from the ARG sign bit.

Example B-17 on page B-26 shows some shift function calls and their return values.

The ROTATE\_LEFT and ROTATE\_RIGHT functions are similar to the shift functions. Example B-16 on page B-25 shows some rotate function declarations.

## **Shift and Rotate Operators**

The numeric\_std package provides shift operators and rotate operators, which work in the same way that shift functions and rotate functions do. The shift operators are sll, srl, sla, and sra. Table B-11 shows some shift and rotate operator declarations. Example B-16 on page B-25 includes some shift and rotate operators.

Table B-11 numeric\_std Shift and Rotate Operators

| Parameters |          |         |             |  |
|------------|----------|---------|-------------|--|
| Operator   | Arg      | Count   | Return type |  |
| "sll"      | UNSIGNED | INTEGER | UNSIGNED    |  |
| "sll"      | SIGNED   | INTEGER | SIGNED      |  |
| "srl"      | UNSIGNED | INTEGER | UNSIGNED    |  |
| "srl"      | SIGNED   | INTEGER | SIGNED      |  |
| "rol"      | UNSIGNED | INTEGER | UNSIGNED    |  |
| "rol"      | SIGNED   | INTEGER | SIGNED      |  |
| "ror"      | UNSIGNED | INTEGER | UNSIGNED    |  |
| "ror"      | SIGNED   | INTEGER | SIGNED      |  |

## Example B-16 Some numeric\_std Shift and Rotate Functions and Shift and Rotate Operators

```
Variable U1, U2: UNSIGNED (7 downto 0);
Variable S1, S2: SIGNED (7 downto 0);
Variable COUNT: NATURAL;
U1 := "01101011";
U2 := "11101011";
S1 := "01101011";
S2 := "11101011";
COUNT := 3;
SHIFT_LEFT (U1, COUNT) = "01011000"
SHIFT_LEFT (S1, COUNT) = "01011000"
SHIFT\_LEFT (U2, COUNT) = "01011000"
SHIFT_LEFT (S2, COUNT) = "01011000"
SHIFT_RIGHT (U1, COUNT) = "00001101"
SHIFT_RIGHT (S1, COUNT) = "00001101"
SHIFT_RIGHT (U2, COUNT) = "00011101"
SHIFT_RIGHT (S2, COUNT) = "111111101"
ROTATE_LEFT (U1, COUNT) = "01011011"
ROTATE_LEFT (S1, COUNT) = "01011011"
ROTATE_LEFT (U2, COUNT) = "01011111"
ROTATE_LEFT (S2, COUNT) = "01011111"
ROTATE_RIGHT (U1, COUNT) = "01101101"
ROTATE_RIGHT (S1, COUNT) = "01101101"
ROTATE_RIGHT (U2, COUNT) = "01111101"
ROTATE_RIGHT (S2, COUNT) = "01111101"
U1 sll COUNT = "01011000"
S1 s11 COUNT = "01011000"
U2 sll COUNT = "01011000"
S2 s11 COUNT = "01011000"
U1 srl COUNT = "00001101"
S1 srl COUNT = "00001101"
U2 srl COUNT = "00011101"
S2 srl COUNT = "111111101"
U1 rol COUNT = "01011011"
S1 rol COUNT = "01011011"
U2 rol COUNT = "01011111"
S2 rol COUNT = "01011111"
U1 ror COUNT = "01101101"
S1 ror COUNT = "01101101"
U2 ror COUNT = "01111101"
S2 ror COUNT = "01111101"
```

## std\_logic\_misc

The std\_logic\_misc package is typically installed in the \$SYNOPSYS/packages/IEEE/src/std\_logic\_misc.vhd directory. It declares the primary data types that the Synopsys VSS tools support.

Boolean reduction functions take one argument (an array of bits) and return a single bit. For example, the AND reduction of "101" is "0", the logical AND of all 3 bits.

Several functions in the std\_logic\_misc package provide Boolean reduction operations for the predefined type STD\_LOGIC\_VECTOR. Example B-17 shows the declarations of these functions.

#### Example B-17 Boolean Reduction Functions

```
function AND_REDUCE (ARG: STD_LOGIC_VECTOR) return UX01; function NAND_REDUCE (ARG: STD_LOGIC_VECTOR) return UX01; function OR_REDUCE (ARG: STD_LOGIC_VECTOR) return UX01; function NOR_REDUCE (ARG: STD_LOGIC_VECTOR) return UX01; function XOR_REDUCE (ARG: STD_LOGIC_VECTOR) return UX01; function XNOR_REDUCE (ARG: STD_LOGIC_VECTOR) return UX01; function AND_REDUCE (ARG: STD_ULOGIC_VECTOR) return UX01; function NAND_REDUCE (ARG: STD_ULOGIC_VECTOR) return UX01; function OR_REDUCE (ARG: STD_ULOGIC_VECTOR) return UX01; function NOR_REDUCE (ARG: STD_ULOGIC_VECTOR) return UX01; function XOR_REDUCE (ARG: STD_ULOGIC_VECTOR) return UX01; function XOR_REDUCE (ARG: STD_ULOGIC_VECTOR) return UX01; function XOR_REDUCE (ARG: STD_ULOGIC_VECTOR) return UX01; function XNOR_REDUCE (ARG: STD_ULOGIC_VECTOR) return UX01;
```

These functions combine the bits of the STD\_LOGIC\_VECTOR, as the name of the function indicates. For example, XOR\_REDUCE returns the XOR of all bits in ARG. Example B-18 shows some reduction function calls and their return values.

#### Example B-18 Boolean Reduction Operations

```
AND REDUCE ("111") = '1'
AND_REDUCE("011")
                    = '0'
OR_REDUCE("000")
                    = '0'
                    = '1'
OR REDUCE ("001")
                  = '1'
= '0'
XOR REDUCE("100")
XOR REDUCE ("101")
NAND REDUCE("111") = '0'
NAND REDUCE("011") = '1'
NOR REDUCE ("000") = '1'
                    = '0'
NOR REDUCE ("001")
XNOR_REDUCE("100") = '0'
XNOR REDUCE("101") = '1'
```

## **Standard Package**

The STANDARD package of data types is included in all VHDL source files by an implicit use clause.

Presto VHDL implements the synthesizable subset of the STANDARD package listed in Example B-19.

## Example B-19 Presto VHDL STANDARD Package

```
package STANDARD is
  type BOOLEAN is (FALSE, TRUE);
  type BIT is ('0', '1');
  type CHARACTER is (
    NUL, SOH, STX, ETX, EOT, ENQ, ACK, BEL,
    BS, HT, LF, VT, FF, CR, SO, SI, DLE, DC1, DC2, DC3, DC4, NAK, SYN, ETB,
    CAN, EM, SUB, ESC, FSP, GSP, RSP, USP,
    ' ', '!', '"', '#', '$', '%', '&', ''',
    '(', ')', '*', '+', ',', '-', '.', '/',
    '0', '1', '2', '3', '4', '5', '6', '7',
     '8', '9', ':', ';', '<', '=', '>', '?',
    '@', 'A', 'B', 'C', 'D', 'E', 'F', 'G',
    'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', '[', '\', ']', '^', '__',
    ''', 'a', 'b', 'c', 'd', 'e', 'f', 'g',
    'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o',
    'p', 'q', 'r', 's', 't', 'u', 'v', 'w',
     'x', 'y', 'z', '{', '|', '}', '~', DEL);
  type INTEGER is range -2147483647 to 2147483647;
  subtype NATURAL is INTEGER range 0 to 2147483647;
  subtype POSITIVE is INTEGER range 1 to 2147483647;
  type STRING is array (POSITIVE range <>)
        of CHARACTER;
  type BIT_VECTOR is array (NATURAL range <>)
        of BIT;
end STANDARD;
```

This section describes the following sythesizable data types:

- Data Type BOOLEAN
- Data Type BIT
- Data Type CHARACTER
- Data Type INTEGER
- Data Type NATURAL
- Data Type POSITIVE
- Data Type STRING
- Data Type BIT\_VECTOR

## Data Type BOOLEAN

The BOOLEAN data type is actually an enumerated type with two values, false and true, where false < true. Logical functions, such as equality (=) and comparison (<) functions, return a BOOLEAN value.

Convert a BIT value to a BOOLEAN value as follows:

```
BOOLEAN_VAR := (BIT_VAR = '1');
```

## **Data Type BIT**

The BIT data type represents a binary value as one of two characters, '0' or '1'. Logical operations such as "and" can take and return BIT values.

Convert a BOOLEAN value to a BIT value as follows:

```
if (BOOLEAN_VAR) then
  BIT_VAR := '1';
else
  BIT_VAR := '0';
end if;
```

## **Data Type CHARACTER**

The CHARACTER data type enumerates the ASCII character set. Nonprinting characters are represented by a three-letter name, such as NUL for the null character. Printable characters are represented by themselves, in single quotation marks, as follows:

```
variable CHARACTER_VAR: CHARACTER;
. . .
CHARACTER_VAR := 'A';
```

## **Data Type INTEGER**

The INTEGER data type represents positive and negative whole numbers.

## **Data Type NATURAL**

The NATURAL data type is a subtype of INTEGER that is used for representing natural (nonnegative) numbers.

## **Data Type POSITIVE**

The POSITIVE data type is a subtype of INTEGER that is used for representing positive (nonzero, nonnegative) numbers.

## Data Type STRING

The STRING data type is an unconstrained array of characters. A STRING value is enclosed in double quotation marks, as follows:

```
variable STRING_VAR: STRING(1 to 7);
. . .
STRING_VAR := "Rosebud";
```

## **Data Type BIT\_VECTOR**

The BIT VECTOR data type represents an array of BIT values.

## Synopsys Package—ATTRIBUTES

The ATTRIBUTES package declares all supported synthesis attributes; the source code is typically installed in the Synopsys libraries \$SYNOPSYS/packages/synopsys/src/attributes.vhd directory. Supported attributes include

- Design Compiler constraint attributes, described in "Synopsys Defined Attributes" on page 6-5
- State vector attribute, described in "State Vector Attribute" on page 2-39

• Enumeration encoding attribute, described in "Enumeration Encoding" on page 2-18 Reference this package when you use synthesis attributes:

library SYNOPSYS;
use SYNOPSYS.ATTRIBUTES.all;

# C

## **VHDL Constructs**

Many VHDL language constructs, although useful for simulation and other stages in the design process, are not relevant to synthesis. Because these constructs cannot be synthesized, Presto VHDL does not support them.

This appendix provides a list of synthesizable VHDL language constructs, with the level of support for each, followed by a list of VHDL reserved words.

This appendix includes the following sections:

- VHDL Construct Support
- Predefined Language Environment
- VHDL Reserved Words

## **VHDL Construct Support**

A construct can be fully supported, ignored, or unsupported. Ignored and unsupported constructs are defined as follows:

- Ignored means that the construct is allowed in the VHDL source but is ignored by Presto VHDL.
- Unsupported means that the construct is not allowed in the VHDL source and that Presto VHDL flags it as an error. If errors are in a VHDL description, the description is not read.

The following subsections describe the constructs:

- Configurations
- Design Units
- Data Types
- Declarations
- Specifications
- Names
- Operators
- Operands and Expressions
- Sequential Statements
- Concurrent Statements
- Lexical Elements

## **Configurations**

The HDL Compiler (Presto Verilog) tool supports standalone, nested, and embedded configurations. For details, see "Configuration Support" on page 1-20.

## **Design Units**

entity

The entity statement part is ignored.

Default values for ports are ignored.

#### generics

In addition to supporting integer-type generics, Presto VHDL adds support for the following types: bit, bit\_vector, std\_ulogic, std\_ulogic\_vector, std\_logic, std\_logic\_vector, signed, and unsigned. Presto VHDL also supports integer arrays and strings as generics.

#### architecture

Multiple architectures are allowed. Global signal interaction between architectures is unsupported.

## configuration

Configuration declarations and block configurations are supported, but only to specify the top-level architecture for a top-level entity. See "Configuration Support" on page 1-20.

The use clauses and attribute specifications are unsupported.

## package

Packages are fully supported.

#### library

Libraries and separate compilation are supported.

## subprogram

Default values for parameters are unsupported. Assigning to indexes and slices of unconstrained out parameters is unsupported, unless the actual parameter is an identifier.

Subprogram recursion is unsupported if the recursion is not bounded by a static value.

Resolution functions are supported for wired-logic and three-state functions only.

Subprograms can be declared only in packages and in the declaration part of an architecture.

## **Data Types**

## enumeration

Enumeration is fully supported.

#### real

Constant real data types are fully supported.

## integer

Infinite-precision arithmetic is unsupported.

Integer types are automatically converted to bit vectors whose width is as small as possible to accommodate all possible values of the type's range. The type's range can be either in unsigned binary for nonnegative ranges or in 2's-complement form for ranges that include negative numbers.

## physical

Physical type declarations are ignored. The use of physical types is ignored in delay specifications.

## floating

Floating-point type declarations are ignored. The use of floating-point types is unsupported except for floating-point constants used with Synopsys defined attributes.

#### array

Array ranges and indexes other than integers are unsupported.

Multidimensional arrays are supported. See Table D-2 on page D-7.

#### record

Record data types are fully supported.

#### access

Access type declarations are ignored, and the use of access types is unsupported.

#### file

File type declarations are ignored, and the use of file types is unsupported.

#### incomplete type declarations

Incomplete type declarations are unsupported.

## **Declarations**

#### constant

Constant declarations are supported except for deferred constant declarations.

#### signal

Register and bus declarations are unsupported. Resolution functions are supported for wired and three-state functions only. Declarations other than from a globally static type are unsupported. Initial values are unsupported.

#### variable

Declarations other than from a globally static type are unsupported. Initial values are unsupported.

#### shared variable

Variable shared by different processes. Shared variables are fully supported.

file

File declarations are unsupported.

#### interface

Buffer and linkage are translated to out and inout, respectively.

#### alias

Alias declarations are supported. See Table D-2 on page D-7.

#### component

Component declarations that list a name other than a valid entity name are unsupported. However, Presto VHDL allows components to be directly instantiated in the design without a component declaration. See "Direct Instantiation of Components" on page 2-3.

#### attribute

Attribute declarations are fully supported, but the use of user-defined attributes is unsupported.

## group

Presto VHDL supports VHDL-93 group declarations. This allows you to create groups of named entities. One useful application of this feature is that you can apply attributes to the group as a whole instead of referencing individual signals. See "Groups" on page 2-17.

## **Specifications**

## attribute

Presto supports the `leftof, `rightof, pos, val, succ, and pred attributes for enum data types. Presto supports the pos, val, succ, and pred attributes for integer and range data types. Presto supports the 'high(n),'low(n),'left(n),'right(n), and 'length(n) attributes on multidimensional arrays. Others and all are unsupported in attribute specifications. User-defined attributes can be specified, but the use of user-defined attributes is unsupported.

#### configuration

Configuration specifications are unsupported.

#### disconnection

Disconnection specifications are unsupported. Attribute declarations are fully supported, but the use of user-defined attributes is unsupported.

## **Names**

#### simple

Simple names are fully supported.

#### selected

Selected (qualified) names outside a use clause are unsupported. Overriding the scopes of identifiers is unsupported.

## operator symbol

Operator symbols are fully supported.

#### indexed

Indexed names are fully supported, with one exception: Indexing an unconstrained out parameter in a procedure is unsupported.

#### slice

Slice names are fully supported, with one exception: Using a slice of an unconstrained out parameter in a procedure is unsupported unless the actual parameter is an identifier.

#### attribute

Only the following predefined attributes are supported: base, left, right, high, low, range, reverse\_range, length, and ascending. The event and stable attributes are supported only as described with the wait and if statements. User-defined attribute names are unsupported. The use of attributes with selected names (name.name'attribute) is unsupported.

Table C-1 shows the values of some array attributes for the variable MY\_VECTOR in Example C-1.

Table C-1 Array Index Attributes

| Attribute Expression    | Value         |  |
|-------------------------|---------------|--|
| MY_VECTOR'left          | 5             |  |
| MY_VECTOR'right         | <b>-</b> 5    |  |
| MY_VECTOR'high          | 5             |  |
| MY_VECTOR'low           | <b>-</b> 5    |  |
| MY_VECTOR'length        | 11            |  |
| MY_VECTOR'range         | (5 downto -5) |  |
| MY_VECTOR'reverse_range | (–5 to 5)     |  |

#### Example C-1 Unconstrained Array Type Definition

```
type BIT_VECTOR is array(INTEGER range <>) of BIT;
   -- An unconstrained array definition
. . .
variable MY_VECTOR : BIT_VECTOR(5 downto -5);
```

See Table 6-2 on page 6-7 for Synopsys defined attributes.

# **Operators**

#### logical

Logical operators are fully supported.

#### relational

Relational operators are fully supported.

#### addition

Concatenation and arithmetic operators are fully supported. The default concatenation support is for the 93 LRM definition. To enable the 87 LRM definition, see "Concatenation" on page 2-28.

#### signing

Signing operators are fully supported.

#### divide, mod, rem

The / (division), mod, and rem operators are fully supported in the std\_logic\_arith and the numeric\_std packages.

#### multiply

The \* multiply operator is fully supported.

#### exponentiation

The \*\* operator is supported only when both operands are constant or when the left operand is 2. Presto VHDL predefines the exponentiation operator for all integer types.

#### absolute value

The abs operator is fully supported. Presto VHDL predefines the absolute value operator for all integer types.

#### operator overloading

Operator overloading is fully supported.

#### short-circuit operation

The short-circuit behavior of operators is not supported.

#### Shift and rotate operators

You can define shift and rotate operators for any one-dimensional array type whose element type is either of the predefined types, BIT or Boolean. The right operand is always of type integer. The type of the result of a shift operator is the same as the type of the left operand. The shift and rotate operators are included in the list of VHDL reserved words in Table C-2 on page C-13. There is more information about the shift and rotate operators that numeric\_std supports in "Shift and Rotate Functions" on page B-23. The shift operators are

```
sll
Shift left logical
srl
Shift right logical
sla
Shift left arithmetic
sra
Shift right arithmetic
The rotate operators are
rol
Rotate left logical
ror
Rotate right logical
```

Example C-2 illustrates the use of shift and rotate operators.

#### Example C-2 Use of Shift and Rotate Operators

```
architecture arch of shft_op is begin

a <= "01101";
q1 <= a sll 1; -- q1 = "11010"
q2 <= a srl 3; -- q2 = "00001"
q3 <= a rol 2; -- q3 = "10101"
q4 <= a ror 1; -- q4 = "10110"
q5 <= a sla 2; -- q5 = "10100"
q6 <= a sra 1; -- q6 = "00110"
```

**XNOR Operator** 

You can define the binary logical operator XNOR for predefined types BIT and Boolean as well as for any one-dimensional array type whose element type is BIT or Boolean. The operands must be the same type and length. The result also has the same type and length. The XNOR operator is included in the list of VHDL reserved words in Table C-2 on page C-13.

#### Example C-3 Showing Use of XNOR Operator

# **Operands and Expressions**

based literal

Based literals are fully supported.

null literal

Null slices, null ranges, and null arrays are unsupported.

physical literal

Physical literals are ignored.

string

Strings are fully supported.

aggregate

The use of types as aggregate choices is supported. Record aggregates are supported.

#### function call

Function calls are supported. Function conversions on input ports are supported, because type conversions on formal ports in a connection specification (port map) are supported. Presto supports the usage of unconstrained type ports when the type of the ports can be deduced. In these cases, you must use analyze/elaborate to read your design. The read command does not support type conversion on formal ports.

qualified expression

Qualified expressions are fully supported.

type conversion

Type conversion is fully supported.

allocator

Allocators are unsupported.

static expression

Static expressions are fully supported.

#### universal expression

Floating-point expressions are unsupported, except in a Synopsys-recognized attribute definition. Infinite-precision expressions are not supported. Precision is limited to 32 bits; all intermediate results are converted to integers.

# **Sequential Statements**

wait

The wait statement is unsupported unless it is in one of the following forms:

Where, VALUE is '0', '1', or an enumeration literal whose encoding is 0 or 1. A wait statement in this form is interpreted to mean "wait until the falling (VALUE is '0') or rising (VALUE is '1') edge of the signal named clock." You cannot use wait statements in subprograms or for-loop statements. If any path through the logic has a wait statement, all the paths must have a wait statement. Presto VHDL supports only one wait statement per process.

#### assert

Assert statements are treated like display statements. An code snippet is shown below.

```
Assert (c) report "...";

-- is the same as

If (!c)
$display ("...");
```

#### report

Report statements are ignored.

#### statement label

Statement labels are ignored.

#### signal

Guarded signal assignment is unsupported. The transport and after signals are ignored. Multiple waveform elements in signal assignment statements are unsupported.

#### variable

Variable statements are fully supported.

#### procedure call

Type conversion on formal parameters is unsupported. Assignment to single bits of vectored ports is unsupported.

if

The if statements are fully supported.

case

The case statements are fully supported.

loop

The for loops are supported, with two constraints: The loop index range must be globally static, and the loop body must not contain a wait statement. The while loops are supported, but the loop body must contain at least one wait statement. Combinational while loops are supported if the iterative bound is statically determinable. The loop statements with no iteration scheme (infinite loops) are supported, but the loop body must contain at least one wait statement.

next

Next statements are fully supported.

exit

Exit statements are fully supported.

return

Return statements are fully supported.

null

Null statements are fully supported.

#### **Concurrent Statements**

block

Guards on block statements are supported. Ports and generics in block statements are unsupported.

process

Sensitivity lists in process statements are ignored.

concurrent procedure call

Concurrent procedure call statements are fully supported.

concurrent assertion

Concurrent assertion statements are ignored.

concurrent signal assignment

The guarded keyword is supported. The transport keyword is ignored. Multiple waveforms are unsupported.

#### component instantiation

Type conversion on formal ports of a connection specification is supported. Presto supports the usage of unconstrained type ports when the type of the ports can be deduced. In these cases, you must use analyze/elaborate to read your design. The read command does not support type conversion on formal ports.

#### generate

The generate statements are fully supported.

# **Lexical Elements**

An identifier in VHDL is a user-defined name for any of these: constant, variable, function, signal, entity, port, subprogram, parameter, or instance.

# **Specifics of Identifiers**

The characteristics of identifiers are as follows:

- They can be composed of letters, digits, and the underscore character (\_).
- Their first character must be a letter, unless it is an extended identifier (see Example C-4 on page C-13).
- They can be of any length.
- · They are case-insensitive.
- All of their characters are significant.

# **Specifics of Extended Identifiers**

The characteristics of extended identifiers are as follows:

- Any of the following can be defined as one:
  - Identifiers that contain special characters
  - Identifiers that begin with numbers
  - · Identifiers that have the same name as a keyword
- They start with a backslash character (\), followed by a sequence of characters, followed by another backslash (\).
- They are case-sensitive.

Example C-4 shows some extended identifiers.

#### Example C-4 Sample Extended Identifiers

| \a+b\  | \3state\  |
|--------|-----------|
| \type\ | \(a&b) c\ |

# **Predefined Language Environment**

severity\_level type

The severity\_level type is unsupported.

time type

The time type is ignored if time variables and constants are used only in after clauses. In the following two code fragments, both the after clause and TD are ignored:

```
constant TD: time := 1.4 ns;
X <= Y after TD;
X <= Y after 1.4 ns;</pre>
```

now function

The now function is unsupported.

**TEXTIO** package

The TEXTIO package is unsupported. The TEXTIO package defines types and operations for communication with a standard programming environment (terminal and file I/O). This package is not needed for synthesis; therefore, Presto VHDL does not support it.

predefined attributes

These predefined attributes are supported: base, left, right, high, low, range, reverse\_range, ascending, and length. The event and stable attributes are supported only in the if and wait statements.

# **VHDL Reserved Words**

Table C-2 lists the words that are reserved for the VHDL language and cannot be used as identifiers:

Table C-2 VHDL Reserved Words

| abs          | access | after  | alias     | all       | and           |
|--------------|--------|--------|-----------|-----------|---------------|
| architecture | array  | assert | attribute | begin     | block         |
| body         | buffer | bus    | case      | component | configuration |

Table C-2 VHDL Reserved Words (Continued)

| constant  | disconnect | downto     | else    | elsif    | end      |
|-----------|------------|------------|---------|----------|----------|
| entity    | exit       | file       | for     | function | generate |
| generic   | group      | guarded    | if      | impure   | in       |
| inertial  | inout      | is         | label   | library  | linkage  |
| literal   | loop       | map        | mod     | nand     | new      |
| next      | nor        | not        | null    | of       | on       |
| open      | or         | others     | out     | package  | port     |
| postponed | procedure  | process    | pure    | range    | record   |
| register  | reject     | rem        | report  | return   | rol      |
| ror       | select     | severity   | shared  | signal   | sla      |
| sll       | sra        | srl        | subtype | then     | to       |
| transport | type       | unaffected | units   | until    | use      |
| variable  | wait       | when       | while   | with     | xnor     |
| xnor      |            |            |         |          |          |



# New Features and Enhancements in Presto VHDL

This appendix describes new features and enhancements in Presto VHDL in the following sections.

- VHDL-93 Supported Features
- New Features and Enhancements History

# **VHDL-93 Supported Features**

Table D-1 lists VHDL-93 specific constructs and the level of support for these constructs in Presto VHDL. The VHDL-93 specific changes are indicated in the column titled "Construct."

The following values are used in the table:

- Reserved—This word is a reserved keyword for the tool.
- Yes—This feature is supported for synthesis.
- Ignored—This feature may be coded but is ignored for synthesis.
- No—This feature is not supported; use will generate an error.

For detailed construct definitions, see the VHDL language reference manual (IEEE 1076-1993).

Table D-1 VHDL-93 Supported Features

| Topic             | Construct | Presto<br>VHDL | Notes |
|-------------------|-----------|----------------|-------|
| Reserved keywords | group     | Reserved       |       |
|                   | impure    | Reserved       |       |
|                   | inertial  | Reserved       |       |
|                   | literal   | Reserved       |       |
|                   | postponed | Reserved       |       |
|                   | pure      | Reserved       |       |
|                   | reject    | Reserved       |       |
|                   | rol       | Reserved       |       |
|                   | ror       | Reserved       |       |
|                   | shared    | Reserved       |       |
|                   | sla       | Reserved       |       |
|                   | sll       | Reserved       |       |
|                   | sra       | Reserved       |       |

Table D-1 VHDL-93 Supported Features (Continued)

| Topic               | Construct                                                                               | Presto<br>VHDL | Notes |
|---------------------|-----------------------------------------------------------------------------------------|----------------|-------|
|                     | srl                                                                                     | Reserved       |       |
|                     | unaffected                                                                              | Reserved       |       |
|                     | xnor                                                                                    | Reserved       |       |
| Identifiers         | Extended identifiers                                                                    | Yes            |       |
| Bit string literals | Bit string literals can be assigned to:<br>std_logic_vector<br>std_ulogic_vector        | Yes            |       |
| Signal assignment   | Assignment supports optional label                                                      | Yes            |       |
|                     | inertial                                                                                | Ignored        |       |
|                     | reject                                                                                  | Ignored        |       |
| Variables           | Assignment supports optional label                                                      | Yes            |       |
|                     | Shared variables                                                                        | Yes            |       |
| Files               | New open_mode values                                                                    | No             |       |
|                     | 'image and 'value attributes                                                            | No             |       |
|                     | VHDL-93 file declaration syntax                                                         | No             |       |
| Record declaration  | "end record <type>;" The record type may optionally be added after "end record".</type> | Yes            |       |
| Standard data types | Extended character sets supported in character and strings                              | Yes            |       |
|                     | New file-related types: file_open_kind, file_open_status                                | No             |       |
| Standard subtypes   | New implicit subtype "delay_length"                                                     | No             |       |
| Shift operators     | sll                                                                                     | Yes            |       |
|                     | srl                                                                                     | Yes            |       |

Table D-1 VHDL-93 Supported Features (Continued)

| Topic                   | Construct                                                                  | Presto<br>VHDL | Notes                                   |
|-------------------------|----------------------------------------------------------------------------|----------------|-----------------------------------------|
|                         | sla                                                                        | Yes            |                                         |
|                         | sra                                                                        | Yes            |                                         |
|                         | rol                                                                        | Yes            |                                         |
|                         | ror                                                                        | Yes            |                                         |
| Logical operators       | xnor                                                                       | Yes            |                                         |
| Alias                   | Alias everything except: generate parameters labels loop parameter         | Yes            | See "Aliases" on page 2-12 for details. |
| Entity                  | "end entity <name>;" Extra keyword "entity" can be used</name>             | Yes            |                                         |
| Architecture            | "end architecture <name>;" Extra keyword "architecture" can be used</name> | Yes            |                                         |
| Groups                  | Group template declaration                                                 | Yes            |                                         |
|                         | Group declaration                                                          | Yes            |                                         |
| Assert                  | Supports optional label                                                    | Ignored        |                                         |
| Block statement         | "label: block is" Extra keyword "is" can be used                           | Yes            |                                         |
| Case                    | Supports optional label                                                    | Yes            |                                         |
| Component declaration   | Component declaration is optional                                          | Yes            |                                         |
|                         | "component <name> is" Extra keyword "is" can be used</name>                | Yes            |                                         |
|                         | "end component <name>;" Component name can be added</name>                 | Yes            |                                         |
| Component instantiation | Direct instantiation with entity/ architecture pair                        | Yes            |                                         |

Table D-1 VHDL-93 Supported Features (Continued)

| Topic                        | Construct                                                                  | Presto<br>VHDL | Notes                                           |
|------------------------------|----------------------------------------------------------------------------|----------------|-------------------------------------------------|
| Configuration declaration    | Configuration declaration can override configuration specification         | No             | Configuration is ignored, use "elaborate -arch" |
|                              | "end configuration <name>;" Extra keyword "configuration" supported</name> | Yes            | ciaborate aron                                  |
| Concurrent signal assignment | unaffected                                                                 | Yes            |                                                 |
| assignment                   | inertial                                                                   | Ignored        |                                                 |
|                              | reject                                                                     | Ignored        |                                                 |
|                              | supports optional label                                                    | Yes            |                                                 |
| Exit statement               | supports optional label                                                    | Yes            |                                                 |
| Function                     | "end function <name>;" Extra keyword "function" can be used</name>         | Yes            |                                                 |
|                              | pure                                                                       | Ignored        | All functions are implicitly considered pure    |
|                              | impure                                                                     | Ignored        |                                                 |
| Generate Statement           | Local declarations                                                         | Yes            |                                                 |
| If statement                 | Supports optional label                                                    | Yes            |                                                 |
| Next statement               | Supports optional label                                                    | Yes            |                                                 |
| Null statement               | Supports optional label                                                    | Yes            |                                                 |
| Packages                     | Shared variables                                                           | Yes            |                                                 |
|                              | Group declaration                                                          | Yes            |                                                 |
| Procedures                   | "end procedure <name>;" Extra keyword "procedure" can be used</name>       | Yes            |                                                 |

Table D-1 VHDL-93 Supported Features (Continued)

| Topic                 | Construct                                      | Presto<br>VHDL | Notes                                        |
|-----------------------|------------------------------------------------|----------------|----------------------------------------------|
| Process               | "process () is" Extra keyword "is" can be used | Yes            |                                              |
|                       | postponed                                      | Ignored        |                                              |
| Wait statement        | Supports optional label                        | Yes            |                                              |
| Predefined attributes | signal'DRIVING                                 | No             |                                              |
| attributes            | signal'DRIVING_VALUE                           | No             |                                              |
|                       | obj'ASCENDING                                  | Yes            |                                              |
|                       | type'IMAGE(obj)                                | No             |                                              |
|                       | type'VALUE(string)                             | No             |                                              |
|                       | obj'SIMPLE_NAME                                | No             | Planned for future<br>Presto VHDL<br>release |
|                       | obj'INSTANCE_NAME                              | No             |                                              |
|                       | obj'PATH_NAME                                  | No             |                                              |

# **New Features and Enhancements History**

Table D-2 lists the new features and enhancements implemented in Presto VHDL.

Table D-2 New Features and Enhancements in Presto VHDL

| Topic                                                                                                             | Description                                                                                        |
|-------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|
| As of the C-2009.06 release                                                                                       |                                                                                                    |
| Automatic detection of RTL language from file extensions by using the read_file-format command.                   | See "Automatic Detection of RTL Language From File Extensions" on page 1-6.                        |
| Reporting simplification by using the hdlin_reporting_level variable.                                             | See "Elaboration Reports" on page 1-7.                                                             |
| Controlling the automatic setting of the size_only attribute on MUX_OPs by using the hdln_mux_size_only variable. | See "MUX_OP Inference" on page 3-10.                                                               |
| As of the B-2008.09 release                                                                                       |                                                                                                    |
| Embedded configurations                                                                                           | See "Configuration Support" on page 1-20.                                                          |
| VHDL 87 concatenation support                                                                                     | See "Concatenation" on page 2-28.                                                                  |
| As of the A-2007.12 release                                                                                       |                                                                                                    |
| keep_signal_name pragma                                                                                           | See "Keeping Signal Names" on page 2-31.                                                           |
| math_real package support                                                                                         | See "math_real Package Support" on page 2-22.                                                      |
| As of the Z-2007.03 release                                                                                       |                                                                                                    |
| Improved set/reset inference                                                                                      | See "D Flip-Flop With Complex Set/Reset Signals" on page 4-25.                                     |
| As of the Y-2006.06 release                                                                                       |                                                                                                    |
| Improved elaboration error reporting                                                                              | Presto VHDL supports hierarchical error reporting. See "Reporting Elaboration Errors" on page 1-8. |

Table D-2 New Features and Enhancements in Presto VHDL (Continued)

| Topic                                               | Description                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Enhanced library linking                            | Beginning with the Y-2006.06 release, Presto VHDL supports automatic linking of mixed language libraries. In Verilog, the default library is the work directory, and you cannot have multiple libraries. In VHDL however, you can have multiple design libraries. In earlier versions, Presto VHDL could not link mixed libraries and returned LINK-5 warnings. See "Reading Designs" on page 1-3. |
| Real data types                                     | Constant real data types are fully supported. See "Data Types" on page C-3.  Example: sample_in : IN fpsigned(4 DOWNTO -7); sample_out <= sample_in + 1.5;                                                                                                                                                                                                                                         |
| Enhanced generic and string support                 | Presto VHDL supports integer arrays and strings as generics. See "Data Types" on page C-3.  Example:  TYPE integer_vect IS ARRAY (natural RANGE <>) OF integer; ki_coeff : integer_vect:=(10,13,15,16);                                                                                                                                                                                            |
|                                                     | generic (g: string:= "abc");                                                                                                                                                                                                                                                                                                                                                                       |
| Enhanced enum, integer, and array attribute support | Presto VHDL expands attribute support for enum and integer data types. See "Specifications" on page C-5.                                                                                                                                                                                                                                                                                           |
| Unconstrained entity and component ports support    | Presto supports the usage of unconstrained type ports when the type of the ports can be deduced. See "Unconstrained Type Ports" on page 2-30 and "Operands and Expressions" on page C-9 and "Concurrent Statements" on page C-11.                                                                                                                                                                  |
|                                                     | Example: COMPONENT my_comp PORT (     sample_in1 : IN unsigned;                                                                                                                                                                                                                                                                                                                                    |
| STD_MATCH                                           | Support for STD_MATCH. See "Don't Care Values in Comparisons" on page 2-44.                                                                                                                                                                                                                                                                                                                        |

# Glossary

#### anonymous type

A predefined or underlying type with no name, such as a universal integer.

# architecture body

The VHDL description of the internal organization or operation of a design entity.

#### **ASIC**

Application-specific integrated circuit.

#### behavioral view

The set of VHDL statements that describe the behavior of a design by using sequential statements. These statements are similar in expressive capability to those found in many other programming languages. See also *data flow view, sequential statement*, and *structural view*.

#### bit-width

The width of a variable, signal, or expression in bits. For example, the bit-width of the constant "5" is 3 bits.

#### character literal

Any value of type CHARACTER in single quotation marks.

#### computable

Any expression whose (constant) value can be determined.

#### concurrent statements

VHDL statements that execute asynchronously in no defined relative order. Concurrent statements make up the data flow and structural views in VHDL.

#### configuration body

The VHDL description of how component instances are bound to design entities to form a complete, linked design.

#### constraints

The designer's specification of design performance goals. Design Compiler uses constraints to direct the optimization of a design to meet area and timing goals.

#### convert

To change one type to another. Only integer types and subtypes are convertible, along with same-size arrays of convertible element types.

#### data flow view

The set of VHDL statements that describe the behavior of a design by using concurrent statements. These descriptions are usually at the level of Boolean equations combined with other operators and function calls. See also *behavioral view*, *concurrent statements*, and *structural view*.

#### **Design Compiler**

The Synopsys tool that synthesizes and optimizes ASIC designs from multiple input sources and formats.

#### design constraints

See constraints.

# design entity

In VHDL, the combination of an entity declaration and one or more architectural bodies constitute a design entity.

#### flip-flop

An edge-sensitive memory device.

#### **HDL**

Hardware Description Language.

#### identifier

A sequence of letters, underscores, and numbers. An identifier cannot be a VHDL reserved word, such as type or loop. An identifier must begin with a letter or an underscore.

#### latch

A level-sensitive memory device.

#### netlist

A network of connected components that together define a design.

#### optimization

The modification of a design in an attempt to improve some performance aspect of the design. Design Compiler optimizes designs and tries to meet specified design constraints for area and speed.

#### package

A collection of declarations that is available to more than one design entity.

#### port

A signal declared in the interface list of an entity.

#### reduction operator

An operator that takes an array of bits and produces a single-bit result, namely the result of the operator applied to each successive pair of array elements.

Glossary GL-2

#### register

A memory device containing one or more flip-flops or latches used to hold a value.

#### resource sharing

The assignment of similar VHDL operations, such as +, to a common netlist cell. Netlist cells are the resources—they are equivalent to built hardware.

#### **RTL**

Register transfer level, a set of structural and data flow statements.

#### sequential statement

The set of VHDL statements that execute in sequence.

#### signal

An electrical quantity that can be used to transmit information. A signal is declared with a type and receives its value from one or more drivers. Signals are created in VHDL through either signal or port declarations.

#### signed value

A value that can be positive, 0, or negative.

#### structural view

The set of VHDL statements used to instantiate primitive and hierarchical components in a design. A VHDL design at the structural level is also called a netlist. See also behavioral view and data flow view.

#### subtype

A type declared as a constrained version of another type.

#### synthesis

The creation of optimized circuits from a high-level description.

#### technology library

A library of ASIC cells available to Design Compiler during the synthesis process. A technology library can contain area, timing, and functional information on each ASIC cell.

#### translation

The mapping of high-level language constructs onto a lower-level form.

#### type

In VHDL, the mechanism by which objects are restricted in the values they are assigned and the operations that can be applied to them.

#### unsigned

A value that can be only positive or 0.

#### variable

A VHDL object local to a process or subprogram that has a single current value.

#### **VHDL**

VHSIC Hardware Description Language, used to describe discrete systems.

Glossary GL-3

# **VHSIC**

Very-high-speed integrated circuit, a high-technology program of the United States Department of Defense.

Glossary GL-4

# Index

| Symbols                              | numeric_std package         |
|--------------------------------------|-----------------------------|
| " - " operator 3-4                   | binary B-17                 |
| " + " operator 3-4                   | assert statement C-10       |
| "* " operator C-7                    | assignment statement        |
| "**" operator C-7                    | indexed name target 2-28    |
| -                                    | asynchronous processes 2-45 |
| "<=" operator B-12                   | attribute declarations C-5  |
| "<" operator 3-4                     | attributes                  |
| ">=" operator B-12                   | ascending C-6               |
| ">" operator 3-4, B-12               | ENUM_ENCODING 6-9           |
| "/ " operator C-7                    | event C-6                   |
|                                      | high C-6                    |
| ۸                                    | infer_mux 6-5               |
| A                                    | left C-6                    |
| adders                               | length C-6                  |
| carry-lookahead adder A-20           | load 6-6                    |
| Definable-Width Adder-Subtracter A-6 | logic_one 6-6               |
| numeric_std package B-17             | logic_zero 6-6              |
| adder-subtracter (example) A-6       | low C-6                     |
| aggregates C-9                       | map_only 2-6                |
| alias declarations                   | map_to_module 6-6           |
| supported C-5                        | max_area 6-6                |
| architecture                         | max_delay 6-6               |
| consistency                          | max_fall_delay 6-6          |
| component instantiation 2-8          | max_rise_delay 6-6          |
| arithmetic functions                 | max_transition 6-6          |
| numeric_std                          | min_delay 6-6               |
| unary B-18                           | min_fall_delay 6-6          |

| min_rise_delay 6-6                 | C                                                  |
|------------------------------------|----------------------------------------------------|
| one_cold 6-6                       | carry-out bit                                      |
| one_hot 6-6                        | example of using B-12                              |
| opposite 6-6                       | case statements                                    |
| range C-6                          | embedded in if-then-else statements, unless        |
| reverse_range C-6                  | the case statement appears in an if                |
| right C-6                          | (CLK'event) 3-16                                   |
| rise_arrival 6-6                   | FSM coding requirements 2-36                       |
| rise_drive 6-6                     | generate MUX_OP cells 3-11                         |
| stable C-6                         | hdlin_infer_mux 3-12                               |
| STATE_VECTOR 2-39                  | hdlin_mux_size_limit 3-13                          |
| sync_set_reset 6-6                 | in an elsif (CLK'event) branch 3-16, 3-17          |
| Synopsys-defined C-7               | in while loops 3-16                                |
| unconnected 6-6                    | infer multibit components 2-41                     |
| VHDL                               | infer MUX_OP cells 3-11                            |
| ENUM_ENCODING 2-19, 6-9            | infer_mux attribute 3-11                           |
| ENUM_ENCODING values 6-9           | infer_mux directive 3-12                           |
| ATTRIBUTES package 1-52, B-1, B-29 | missing assignment in a case statement branch 3-16 |
| D                                  | SELECT_OP Inference 3-8                            |
| В                                  | supported constructs C-11                          |
| binary arithmetic functions        | Supports optional label D-4                        |
| example B-10                       | used in multiplexing logic 3-8                     |
| numeric_std package B-18           | clock, bused 4-15                                  |
| bit name                           | combinational feedback                             |
| variable type 7-5                  | paths 3-17                                         |
| bit vectors                        | comparison functions                               |
| variable type 7-5                  | numeric_std B-19                                   |
| BIT_VECTOR type B-5, B-27          | component                                          |
| bit-blasting 7-7                   | declaration                                        |
| bit-width (of operands) 2-24       | writing out 7-4                                    |
| Boolean reduction functions B-26   | implication                                        |
| built_in directive                 | three-state driver 5-1                             |
| logic functions B-2                | instantiation                                      |
| type conversion B-3                | search order 2-5                                   |
| using B-2                          | mapping subprogram to 2-8                          |
| built_in pragma                    | component declarations C-5                         |
| example of using B-2               | computable operands 2-25                           |
| bused clock                        | conditionally assigned variable 4-14               |
| syntax 4-15                        | conditionally specified signal 3-18                |
|                                    | constant declaration                               |

| supported C-4                               | vhdlout_bit_vector_type 7-5             |
|---------------------------------------------|-----------------------------------------|
| constant propagation 3-5                    | vhdlout_dont_create_dummy_nets 7-3      |
| continuous assignments                      | vhdlout_equations 7-3                   |
| hdlin_prohibit_nontri_multiple_drivers 6-13 | vhdlout_follow_vector_direction 7-3     |
| control unit (example)                      | vhdlout_local_attributes 7-3            |
| counting A-14                               | vhdlout_one_name 7-5                    |
| state machine A-11                          | vhdlout_preserve_hierarchical_types 7-7 |
| Controlling Register Inference 4-5          | vhdlout_separate_scan_in 7-3            |
| conversion functions                        | vhdlout_single_bit 7-7                  |
| arithmetic                                  | vhdlout_three_state_name 7-6            |
| binary B-9                                  | vhdlout_three_state_res_func 7-6        |
| numeric_std package                         | vhdlout_unknown_name 7-6                |
| TO_INTEGER B-17                             | vhdlout_upcase 7-4                      |
| TO_SIGNED B-17                              | vhdlout_use_packages 7-4                |
| TO_UNSIGNED B-17                            | vhdlout_wired_and_res_func 7-6          |
| std_logic_arith package B-8                 | vhdlout_wired_or_res_func 7-6           |
| _ 3 _ 1                                     | vhdlout_write_components 7-4            |
| _                                           | vhdlout_zero_name 7-6                   |
| D                                           | write variables 7-3                     |
| data type                                   | Design Compiler 2-34                    |
| abstract                                    | component instantiation 2-5             |
| BOOLEAN B-28                                | write command 7-2                       |
| array attributes                            | directives                              |
| index C-6                                   | built_in 7-12, B-6                      |
| BIT B-28                                    | identifying B-6                         |
| BIT_VECTOR B-29                             | dc_script_begin 6-3                     |
| BOOLEAN B-28                                | dc_script_end 6-3                       |
| CHARACTER B-28                              | keep_signal_name 2-31                   |
| integer                                     | map_to_entity 2-8, 6-3                  |
| defined B-29                                | resolution_method 2-33                  |
| supported C-3                               | return_port_name 2-8, 6-3               |
| SYNOPSYS                                    | using 2-33                              |
| std_logic_signed 2-17                       | don't care 3-17                         |
| data types                                  | don't care inference                    |
| numeric_std                                 | simulation versus synthesis 2-44        |
| SIGNED B-16                                 | don't cares                             |
| UNSIGNED B-16                               | encoding values for the ENUM_ENCODING   |
| dc_script_end directive 6-3, 6-4            | attribute 6-9                           |
| dc_shell variables                          | in case statements 3-17                 |
| vhdlout_ 7-3                                | simulation/synthesis mismatch 2-44      |
| vhdlout_bit_type 7-5                        |                                         |

| sequential A-9                                  |
|-------------------------------------------------|
| Mealy finite state machine A-18                 |
| Moore finite state machine A-16                 |
| PLA A-33                                        |
| ROM A-2                                         |
| serial-to-parallel converter counting bits A-26 |
| shifting bits A-31                              |
| three-state component                           |
| registered input 5-7                            |
| two-phase clocked design 4-35                   |
| waveform generator                              |
| simple A-4                                      |
| writing out port types 7-9                      |
| Explicit bit-truncation 3-5                     |
| extended identifier C-12                        |
|                                                 |
| _                                               |
| F                                               |
| falling_edge 4-18                               |
| feedback paths 3-17                             |
| file declarations C-5                           |
| file formats, automatic detection of 1-6        |
| finite state machine 2-35                       |
| automatic detection 2-35                        |
| finite state machines                           |
| automatic detection 2-35                        |
| coding guidelines 2-36                          |
| fsm_auto_inferring 2-35                         |
| Inference Report 2-39                           |
| Mealy finite state machine A-18                 |
| Moore finite state machine A-16                 |
| STATE_VECTOR attribute 2-39                     |
| flip 1-18, 4-36                                 |
| flip-flop                                       |
| async_set_reset 4-6                             |
| clocked_on_also 4-7                             |
| clocked_on_also attribute 4-32                  |
| creating parameterized models 1-18              |
| D Flip-Flop With Asynchronous Reset 4-20        |
| D Flip-Flop With Asynchronous Set 4-19          |
|                                                 |

| D Flip-Flop With Asynchronous Set and                                   | Negative-Edge-Triggered D Flip-Flop 4-18     |
|-------------------------------------------------------------------------|----------------------------------------------|
| Reset 4-21                                                              | Negative-Edge-Triggered D Flip-Flop Using    |
| D Flip-Flop With Synchronous and                                        | 'event 4-18                                  |
| Asynchronous Load 4-26                                                  | Negative-Edge-Triggered D Flip-Flop Using    |
| D Flip-Flop With Synchronous Reset 4-23                                 | falling_edge 4-18                            |
| D Flip-Flop With Synchronous Set 4-22                                   | on the input pin of a three-state buffer 5-7 |
| forcing specific GTECH components 2-6                                   | one_cold 4-7                                 |
| hdlin_ff_always_ async_set_reset 4-5                                    | Positive-Edge-Triggered D Flip-Flop 4-16     |
| hdlin_ff_always_ sync_set_reset 4-5                                     | Positive-Edge-Triggered D Flip-Flop Using    |
| hdlin_keep_feedback 4-5                                                 | 'event Attribute 4-17                        |
| if (falling_edge (CLK)) then 4-15                                       | Positive-Edge-Triggered D Flip-Flop Using    |
| if (rising_edge (CLK)) then 4-15                                        | rising_edge 4-17                             |
| If the technology library does not contain the                          | Register banks 4-36                          |
| specific inferred flip-flop 4-3                                         | SEQGENs 4-2                                  |
| infer a register as an FSM state register 2-36                          | SIGNAL'event and SIGNAL = '0' 4-15           |
| infer as multibit 2-40                                                  | sync_set_reset 4-6                           |
| inference design requirements 4-36                                      | unmapped master-slave generic cell           |
| Inference Report for a D Flip-Flop With                                 | (MSGEN) 4-32                                 |
| Asynchronous Reset 4-20                                                 | used to describe the master-slave latch 4-32 |
| Inference Report for a D Flip-Flop With                                 | using the IEEE std_logic_1164 package 4-15   |
| Asynchronous Set 4-19                                                   | with bidirectional pins 4-36                 |
| Inference Report for a D Flip-Flop With                                 | with multiple clock inputs 4-36              |
| Asynchronous Set and Reset 4-21                                         | with three-state outputs 4-36                |
| Inference Report for a D Flip-Flop With                                 | FSM inference report 2-37                    |
| Synchronous and Asynchronous Load                                       | fully specified                              |
| 4-26                                                                    | signal 3-17                                  |
| Inference Report for a D Flip-Flop With                                 | variable 3-17                                |
| Synchronous Reset 4-24                                                  | function                                     |
| Inference Report for a D Flip-Flop With                                 | resolution                                   |
| Synchronous Set 4-23                                                    | example 2-33                                 |
| Inference Report for a JK Flip-Flop 4-30                                | functions 6-4                                |
| Inference Report for a JK Flip-Flop With                                | implementations                              |
| Asynchronous Set and Reset 4-31                                         | •                                            |
| Inference Report for Negative-Edge-                                     | mapped to gates 2-10                         |
| Triggered D Flip-Flop 4-19 Inference Report for Positive-Edge-Triggered |                                              |
| D Flip-Flop 4-17                                                        | G                                            |
| Inferring D Flip-Flops 4-15                                             | _                                            |
| JK Flip-Flop With Asynchronous Set and                                  | GTECH.db generic library                     |
| Reset 4-31                                                              | component instantiation                      |
| JK flip-flops 4-29                                                      | structural design 2-6                        |
| master-slave latches 4-32                                               | link_library variable                        |
| Multiple Flip-Flops with Asynchronous and                               | Design Compiler 2-7                          |
| Synchronous Controls 4-27                                               | guard                                        |

| on block statement C-11                            | infers a D flip-flop 4-15                       |
|----------------------------------------------------|-------------------------------------------------|
| guarded keyword C-11                               | infers a D latch 4-9                            |
|                                                    | optional label D-5                              |
| Н                                                  | support for the event and stable attributes C-6 |
| hdlin_infer_enumerated_types 6-11                  | supported construct C-11                        |
| hdlin_infer_function_local _latches 6-11           | Implicit bit-truncation 3-6                     |
| hdlin_infer_function_local_latches 6-11            | incompletely specified case statement 3-17      |
| hdlin_infer_mux 3-12                               | incompletely specified signals and variables    |
| hdlin_keep_signal_name variable 2-31               | 3-17                                            |
| hdlin_mux_oversize_ratio 3-13, 6-11                | indexed name target 2-28                        |
| hdlin_mux_size_limit 3-13                          | infer_mux 3-11, 3-12                            |
| hdlin_mux_size_min 3-13, 6-11                      | inference report                                |
| hdlin_mux_size_only variable 3-13, 6-12            | description 5-2                                 |
| hdlin_no_sequential_mapping 6-12                   | inference reports 4-4, 5-2 inferred registers   |
| hdlin_one_hot_one_cold_on 6-12                     | limitations 4-36                                |
| hdlin_optimize_array_references 6-12               | instantiation                                   |
| hdlin_optimize_enum_types 6-12                     | component                                       |
| hdlin_preserve_sequential variable 4-37            | search order 2-5                                |
| hdlin_prohibit_nontri_multiple _drivers 6-13       | integer data type                               |
| hdlin_report_fsm directive 2-35                    | encoding 2-17                                   |
| hdlin_reporting_level variable 1-7, 2-37, 4-4, 5-2 | subrange 2-17                                   |
| hierarchy                                          | K                                               |
| preserving types 7-7                               |                                                 |
| high impedance state 5-1                           | keep_signal_name directive 2-31                 |
|                                                    | Keeping Signal Names 2-31                       |
| I                                                  |                                                 |
| 1                                                  | L                                               |
| identifiers                                        | language constructs, VHDL                       |
| characteristics C-12 extended C-12                 | concurrent statements                           |
| if statements                                      | assertion C-11                                  |
| D flip-flop inference requirements 4-36            | block C-11                                      |
| hdlin_infer_mux 3-12                               | generate C-12                                   |
| in an invalid use of a conditionally assigned      | procedure call C-11                             |
| variable 4-14                                      | process C-11                                    |
| in case statements 3-16                            | signal assignment C-11<br>data types            |
| incompletely specified 4-9                         | access C-4                                      |
| infer MUX_OP cells 3-11                            |                                                 |

| array C-4                        | aggregate C-9                   |
|----------------------------------|---------------------------------|
| enumeration C-3                  | allocator C-9                   |
| file C-4                         | based literal C-9               |
| floating C-4                     | function call C-9               |
| incomplete type declarations C-4 | null literal C-9                |
| integer C-3                      | physical literal C-9            |
| physical C-4                     | static expression C-9           |
| record C-4                       | string C-9                      |
| declaration                      | type conversion C-9             |
| attribute C-5                    | universal expression C-10       |
| component C-5                    | operators                       |
| constant C-4                     | addition C-7                    |
| file C-5                         | logical C-7                     |
| interface C-5                    | miscellaneous C-7               |
| signal C-4                       | multiplying C-7                 |
| variable C-4                     | relational C-7                  |
| design units                     | short-circuit operation C-7     |
| architecture C-3                 | signing C-7                     |
| configuration C-3                | predefined language environment |
| entity C-2                       | now function C-13               |
| library C-3                      | predefined attributes C-13      |
| package C-3                      | severity_level type C-13        |
| subprogram C-3                   | TEXTIO package C-13             |
| expressions                      | time type C-13                  |
| aggregate C-9                    | reserved words C-13             |
| allocator C-9                    | sequential statements           |
| based literal C-9                | assertion C-10                  |
| function call C-9                | case C-11                       |
| null literal C-9                 | exit C-11                       |
| physical literal C-9             | if C-11                         |
| static expression C-9            | loop C-11                       |
| string C-9                       | next C-11                       |
| type conversion C-9              | null C-11                       |
| universal expression C-10        | procedure call C-10             |
| names                            | report C-10                     |
| attribute C-6                    | return C-11                     |
| indexed C-6                      | signal C-10                     |
| operator symbol C-6              | statement labels C-10           |
| selected C-6                     | variable C-10                   |
| simple C-6                       | wait C-10                       |
| slice C-6                        | specifications                  |
| operands                         | attribute C-5                   |
|                                  |                                 |

configuration C-5 M disconnection C-5 map\_only attribute 2-6 latches map to entity directive 2-8 async\_set\_reset attribute 4-11 math real package support 2-22 clocked on also 4-32 Mealy finite state machine (example) A-18 D latch inference 4-10 Moore finite state machine (example) A-16 D latch with an asynchronous reset 4-12 D Latch With Asynchronous Set 4-11 multiplexina logic generic sequential cells (SEQGENs) 4-2 case statements embedded in if-then-else statements 3-16 hdlin infer block local latches 6-11 case statements in an elsif (CLK'event...) If the technology library does not contain the 3-17 specific inferred latch 4-3 case statements in while loops 3-16 infer multibit components 2-41 case statements that contain an if statement Inference Report for an SR Latch 4-8 Inference Report for D Latch With case statements that contain don't care Asynchronous Set 4-11 values 3-17 master-slave latches 4-32 case statements that have a missing case Multiport latches 4-36 statement branch 3-16 one cold attribute 4-13 Design Compiler implementation 3-10 read a conditionally assigned variable 4-14 hdlin infer mux variable 3-12 Register banks 4-36 hdlin\_mux\_oversize\_ ratio 3-13 SR latch inference 4-7 hdlin mux oversize ratio 6-11 Unintended Latches in Combinational Logic hdlin mux size limit 3-13 3-17 hdlin mux size min 3-13, 6-11 variables declared in subprograms 4-10 implement conditional operations implied by Verbose Inference Report for a D Latch 4-10 if and case statements 3-8 with three-state outputs 4-36 incompletely specified case statement 3-17 license requirements 1-54 infer MUX\_OP cells 3-10 loops infer mux attribute 3-11, 6-5 case statements inference report for MUX\_OPs 3-14 in while loops 3-16 MUX OP cells 3-8 combinational feedback loop 3-19 MUX OP Inference Limitations 3-16 create a ripple carry adder A-7 preferentially map multiplexing logic to enumerated types as indexes 2-16 multiplexers 3-8 for...loop parameters 2-25 SELECT OP cells 3-8 generate loop 2-2 --synopsys infer\_mux directive 3-11 hdlin keep feedback 4-5 warning message 3-17 support in Presto VHDL C-11 with if and case statements 3-8 that iterates across each bit in the given multiplication using shifts B-15 value A-8 MUX\_OP cells, setting the size\_only attribute using wait statements in for-loop statements 3-13 C-10 MUX OP Inference 3-10

| N                                     | operators                     |
|---------------------------------------|-------------------------------|
| names                                 | ordering                      |
| slice names 2-25                      | and enumerated types 2-45     |
| N-bit adder                           | rotate                        |
| declaration                           | numeric_std package B-24      |
| example, ripple-carry 2-7             | shift                         |
| ripple-carry design 2-6               | numeric_std package B-24      |
| new features and differences D-1      | optimization 2-35             |
| noncomputable operands 2-26           | ordering                      |
| numeric_std package                   | functions                     |
| accessing B-16                        | example B-13                  |
| arithmetic functions                  | overloading<br>enumeration    |
| binary B-18                           | literal 2-18                  |
| unary B-18                            | merai 2-10                    |
| comparison functions                  |                               |
| ordering B-19                         | Р                             |
| data types                            | PLA (example) A-33            |
| UNSIGNED B-16                         | ports                         |
| IEEE documentation 1-52, B-1          | bit-blasting 7-7              |
| location B-16                         | pragmas. See directives       |
| logical operators                     | predefined attributes         |
| AND B-22                              | supported C-13                |
| NAND B-22                             | processes                     |
| NOR B-22                              | asynchronous 2-45             |
| NOT B-22                              | sensitivity lists 2-46        |
| OR B-22                               | synchronous 2-45              |
| XNOR B-22                             | Syllomonicus 2 16             |
| XOR B-22                              | _                             |
| resize function B-17                  | R                             |
| rotate                                | read_file -format command 1-6 |
| functions B-23                        | register inference            |
| operators B-24                        | D latch 4-9                   |
| shift                                 | edge expressions 4-15         |
| functions B-23                        | if versus wait 4-15           |
| operators B-24                        | signal edge 4-15              |
| use with std_logic_arith package B-15 | SR latch 4-7                  |
|                                       | wait versus if 4-15           |
| 0                                     | report statement C-10         |
| operands                              | resize function               |
| bit-width 2-24                        | numeric_std package B-17      |
| computable 2-25                       | resolution function           |
|                                       | . 000144011 141104011         |

| directives                             | state machine (example)              |
|----------------------------------------|--------------------------------------|
| resolution_method three_state 2-33     | controller A-11                      |
| resolution_method wired_and 2-33       | Mealy A-18                           |
| resolution_method wired_or 2-33        | Moore A-16                           |
| writing out 7-6                        | state vector                         |
| vhdlout_wired_and_res_func 7-6         | attribute 2-39                       |
| vhdlout_wired_or_res_func 7-6          | STATE_VECTOR attribute 2-39          |
| resolution_method                      | statement                            |
| three_state directive 2-33             | assignment                           |
| wired_and directive 2-33               | indexed name target, syntax 2-28     |
| wired_or directive 2-33                | statement labels C-10                |
| rising_edge 1-4, 4-17                  | std_logic_1164 package B-2           |
| ROM (example) A-2                      | std_logic_arith package              |
| rotate                                 | "<=" function B-12                   |
| functions                              | ">=" function B-12                   |
| numeric_std package B-23               | ">" function B-12                    |
| operators C-8                          | arithmetic functions B-9             |
| numeric_std package B-24               | Boolean reduction functions B-26     |
|                                        | built_in functions B-6               |
| S                                      | comparison functions B-12            |
|                                        | conversion functions B-9             |
| SELECT_OP 3-8                          | data types B-7                       |
| sensitivity lists 2-46                 | modifying the package B-6            |
| serial-to-parallel converter (example) | ordering functions B-12              |
| shifting bits A-31                     | shift function B-14                  |
| set_map_only command 2-6               | using the package B-4                |
| shared variable C-4                    | std_logic_misc package B-26          |
| shift                                  | subprogram                           |
| functions                              | mapping to components                |
| example B-14                           | example 2-9                          |
| numeric_std B-23                       | matching entity 2-8                  |
| operations B-15                        | subrange                             |
| operators                              | integer data type 2-17               |
| numeric_std package B-24               | SYN_FEED_THRU                        |
| signals                                | example of using B-4                 |
| edge detection 4-15                    | synchronous                          |
| supported C-4                          | processes 2-45                       |
| SIGNED data type                       | Synopsys packages                    |
| defined B-7                            | std_logic_misc B-26                  |
| simulation                             | Synopsys-defined VHDL attributes C-7 |
| don't care values 2-44                 | synthetic comments. See directives   |

|                                            | BII_VECTOR data type B-29             |
|--------------------------------------------|---------------------------------------|
| three-state                                | BOOLEAN data type B-28                |
| gate 5-6                                   | CHARACTER data type B-28              |
| registered enable 5-7                      | component                             |
| without registered enable 5-7              | implication 2-8                       |
| inference 5-1                              | concurrent statements                 |
| registered drivers 5-6, 5-7                | supported C-11                        |
| registered input 5-7                       | data type, supported                  |
| vhdlout_three_state_name variable 7-6      | enumeration C-3                       |
| time type C-13                             | data type, unsupported                |
| • •                                        | integer C-3                           |
| transport keyword C-11                     | declarations C-4                      |
| two-phase design 4-35                      | design                                |
| type                                       | units C-2                             |
| conversion variable                        | writing out 7-2                       |
| functions 7-7                              | expressions, supported C-9            |
| variable                                   | integer data type 2-17, B-29          |
| preserving hierarchy 7-7                   | names C-6                             |
|                                            | NATURAL subtype B-29                  |
| U                                          | operators                             |
|                                            | supported C-7                         |
| unary                                      | package<br>composition 2-7            |
| arithmetic functions                       | ports, writing out 7-7                |
| example B-11                               | POSITIVE subtype B-29                 |
| numeric_std B-18                           | predefined                            |
| unconstrained arrays                       | language environment C-13             |
| example using A-6                          | sensitivity lists 2-46                |
| unloaded sequential cell preservation 4-37 | sequential statements, supported C-10 |
| UNSIGNED data type                         | specifications C-5                    |
| defined B-7                                | STRING type B-29                      |
| numeric_std package B-16                   | three-state components 5-1            |
|                                            | writing out 7-2                       |
| V                                          | _                                     |
| V                                          | VHDL assertions 4-7                   |
| variables                                  | VHDL Compiler                         |
| conditionally assigned 4-14                | attributes                            |
| hdlin_keep_signal_name 2-31                | Synopsys C-6 write_script command 7-3 |
| vhdlout_top_configuration_arch_name 7-8    | _ ·                                   |
| vhdlout_top_configuration_entity_name 7-8  | component instantiation, entities 2-7 |
| vhdlout_top_configuration_name 7-8         | don't care information 2-34           |
| VHDL                                       |                                       |
| BIT data type B-28                         | enumeration encoding 2-18             |

integer encoding 2-17 sensitivity lists 2-46 STATE\_VECTOR attribute 2-39 vhdlout variables 7-3 vhdlout bit type variable 7-5 vhdlout\_bit\_vector\_type variable 7-5 vhdlout\_dont\_create\_dummy\_nets variable 7-3 vhdlout\_equations variable 7-3 vhdlout follow vector direction variable 7-3 vhdlout local attributes variable 7-3 vhdlout one name variable 7-5 vhdlout\_package\_naming\_style 7-7 vhdlout\_preserve\_hierarchical\_types variable 7-7 vhdlout\_separate\_scan\_in variable 7-3 vhdlout single bit variable 7-7 vhdlout three state name variable 7-6 vhdlout\_three\_state\_res\_func variable 7-6 vhdlout top configuration arch name 7-8

vhdlout\_top\_configuration\_entity\_name
variable 7-8
vhdlout\_top\_configuration\_name variable 7-8
vhdlout\_unknown\_name variable 7-6
vhdlout\_upcase variable 7-4
vhdlout\_use\_packages variable 7-4
vhdlout\_wired\_and\_res\_func variable 7-6
vhdlout\_wired\_or\_res\_func variable 7-6
vhdlout\_write\_architecture variable 7-4
vhdlout\_write\_components variable 7-4
vhdlout\_write\_entity variable 7-4
vhdlout\_write\_top\_configuration variable 7-4
vhdlout\_zero name variable 7-6

# W

warnings
asynchronous designs 2-34
waveform generator (example)
simple A-4
write command 7-2
writing out VHDL 7-2